mysql 两表关联 主键自增加 插入数据问题 100
比如说我现在这里有两张表。。一张商品基本信息表basic结构如下:字段名称product_id(商品ID主键自动增长)title(商品标题)price(商品价格)comm...
比如说我现在这里有两张表。。
一张商品基本信息表basic结构如下:
字段名称
product_id (商品ID 主键 自动增长)
title (商品标题)
price(商品价格)
commentCount(商品评论数量)
一张商品详细参数表attr
attr_id (属性ID 主键 自动增长)
attr_name(参数名称)
attr_value(参数值)
product_id(商品ID)
当我要将一个商品的所有信息放到这两张表里的时候。。
insert into basic values (null,'华硕笔记本最新款','3800.00','8026'); 先将商品的基本信息插入basic表
insert into attr values(null,'品牌','华硕','这里的商品ID该写什么呀')
insert into attr values(null,'型号','AX550','这里的商品ID该写什么呀')
。。。其他参数。。
最主要我最后是想关联查询。通过商品参数表查询一个商品都有哪些参数。因为每个商品的参数是不太一样的。
求解释。。老大神。。高分送上。高人现身吧。。 展开
一张商品基本信息表basic结构如下:
字段名称
product_id (商品ID 主键 自动增长)
title (商品标题)
price(商品价格)
commentCount(商品评论数量)
一张商品详细参数表attr
attr_id (属性ID 主键 自动增长)
attr_name(参数名称)
attr_value(参数值)
product_id(商品ID)
当我要将一个商品的所有信息放到这两张表里的时候。。
insert into basic values (null,'华硕笔记本最新款','3800.00','8026'); 先将商品的基本信息插入basic表
insert into attr values(null,'品牌','华硕','这里的商品ID该写什么呀')
insert into attr values(null,'型号','AX550','这里的商品ID该写什么呀')
。。。其他参数。。
最主要我最后是想关联查询。通过商品参数表查询一个商品都有哪些参数。因为每个商品的参数是不太一样的。
求解释。。老大神。。高分送上。高人现身吧。。 展开
3个回答
展开全部
可用函数 mysql_insert_id() 获取最新插入数据库中数据的product_id。
直接输出 mysql_insert_id() 返回的是最新插入数据的ID ;
如果你的product_id是 unsigned int,或者 bigint 的 。那么,可能是返回的是错误的。而要用 LAST_INSERT_ID()代替。
insert into basic values (null,'华硕笔记本最新款','3800.00','8026');
$product_id = mysql_insert_id(); //获取刚插入product的id
insert into attr values(null,'品牌','华硕',"$product_id");
insert into attr values(null,'型号','AX550',"$product_id");
`````````````````
可左关联表查询:
SELECT * FROM attr LEFT JOIN basic ON attr.product_id = basic.product_id;
展开全部
刚好看到就说下。
一、详细参数表 的product_id 对应的外键应该是基本表basic的product_id。
二、通过商品参数表 关联查询,使用join会耗费许多系统资源不建议, 直接如下使用效率更高 select * from attr b where produc_id =(select product_id from attr a where ( 你指定的参数表具体条件) ) 结果集应该为改参数表对应的具体商品所有的参数详情。
另外如果想要查询不同商品的及其参数的详情 就是指查找参数表为product_id 基本表(商品名以及价格) 参数表(该商品的所有参数) 可以使用group by 可以解决。
一、详细参数表 的product_id 对应的外键应该是基本表basic的product_id。
二、通过商品参数表 关联查询,使用join会耗费许多系统资源不建议, 直接如下使用效率更高 select * from attr b where produc_id =(select product_id from attr a where ( 你指定的参数表具体条件) ) 结果集应该为改参数表对应的具体商品所有的参数详情。
另外如果想要查询不同商品的及其参数的详情 就是指查找参数表为product_id 基本表(商品名以及价格) 参数表(该商品的所有参数) 可以使用group by 可以解决。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这些其实分布完成,不过,如果你想一部完成,你要研究下mysql的触发器,你只要给一个商品INSERT执行绑定一个trigger,就可以实现同步,具体语法你百度下,这个比较实际,省了不少代码,你唱早了触发器后,可以多次使用
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |