mysql按条件统计count,及关联查询显示count为0的记录问题
发表于:2021-12-24 09:43:51浏览:4628次
业务场景是这样的。我在关联查询时,需要按不同的条件,统计出两个或者多个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`
栏目分类全部>
推荐文章
- windows cmd “Loaded Configuration File none”未加载php.ini的解决办法
- BootCDN——稳定、快速、免费的前端开源项目 CDN 加速服务
- mysql 一张表两行数据某些字段值相互更换
- 图片变形处理,可设置CSS属性object-fit: cover完美解决
- Laravel8入门教程(一):Laravel8的安装与环境搭建
- php面向对象什么意思,全面解析PHP面向对象的三大特征
- gitee + PicGo 搭建个人免费图床
- 整理的一些常用到的 Nginx 配置
- 清空 /var/log/journal 文件的方法
- Linux下搭建SVN服务器及自动更新项目文件到web发布目录(www)
