mysql按条件统计count,及关联查询显示count为0的记录问题
业务场景是这样的。我在关联查询时,需要按不同的条件,统计出两个或者多个count。并且也要显示出count为0的记录。拆分问题:1、按条件统计多个count2、使用count后关联查询失效。count为0的记录不显示。解决方法如下:1、按条件统计count可以用如下方法COUNT(IF(条件 , 统计字段, NULL))SELECT t1.*...
·
业务场景是这样的。我在关联查询时,需要按不同的条件,统计出两个或者多个count。并且也要显示出count为0的记录。
拆分问题:
1、按条件统计多个count
2、使用count后关联查询失效。count为0的记录不显示。
解决方法如下:
1、按条件统计count可以用如下方法
COUNT(IF(条件 , 统计字段, NULL))
SELECT t1.*,COUNT(IF(t3.status = 1 , t2.id, NULL)) AS downCount,COUNT(IF(t3.status = 2 , t2.id, NULL)) AS upCount FROM ex_exam_question t1
LEFT JOIN ex_exam_question_suggestion t2 ON t2.question_id = t1.`id`
LEFT JOIN ex_exam_question_suggestion_item t3 ON t2.suggestion_item_id = t3.id
WHERE 1=1
2、解决关联查询失效问题
通过加group by来解决
将上述sql修改如下
SELECT t1.*,COUNT(IF(t3.status = 1 , t2.id, NULL)) AS downCount,COUNT(IF(t3.status = 2 , t2.id, NULL)) AS upCount FROM ex_exam_question t1
LEFT JOIN ex_exam_question_suggestion t2 ON t2.question_id = t1.`id`
LEFT JOIN ex_exam_question_suggestion_item t3 ON t2.suggestion_item_id = t3.id
WHERE 1=1 GROUP BY t1.`id`

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐
所有评论(0)