mysql查询


多表连接查询

有段时间没有编程,再次写个SQL语句都有点困难了,错误重重的,好记性不如烂笔头,记个博客吧!

有这么三个表

商品类型表--goods_type

商品属性表 -- attribute


商品属性分组表

【需求】做一个商品类型列表页面,需要展示商品类型名称、属性分组、属性个数等信息,如下图

【第一次写的sql】

select a.goods_type_id,a.goods_type_name,a.is_show,a.sort_oder,b.attr_num,d.attr_group_num from
(select goods_type_id,goods_type_name,is_show,sort_oder from goods_type where is_show=1) as a
left join
(select count(*) as attr_num,goods_type_id from attribute where is_show=1 group by goods_type_id) as b
left join
(select count(*) as attr_group_num,c.goods_type_id from (select attr_group_id,goods_type_id from attribute where 
is_show=1 group by attr_group_id) as c group by c.goods_type_id ) as d
on d.goods_type_id = a.goods_type_id and b.goods_type_id = a.goods_type_id

结果执行后,总是提示

出现错误之后,我把sql语句拆分成三条语句分别执行,结果都是ok的,错到哪里了,尼玛,sql语句中哪有一个引号的,好是郁闷啊,后来在网上查了一下,原来关联查询的条件位置写错了

select a.goods_type_id,a.goods_type_name,a.is_show,a.sort_order,b.attr_num,d.attr_group_num from
(select goods_type_id,goods_type_name,is_show,sort_order from goods_type where is_show=1) as a
left join 
(select count(*) as attr_num,goods_type_id from attribute where is_show=1 group by goods_type_id) as b
on b.goods_type_id = a.goods_type_id 
left join
(select count(*) as attr_group_num,c.goods_type_id from (select attr_group_id,goods_type_id from attribute where 
is_show=1 group by attr_group_id) as c group by c.goods_type_id ) as d
on d.goods_type_id = a.goods_type_id




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值