扫码关注官方订阅号
SELECT COUNT(a.*),AVG(b.ps_score),COUNT(b.*)FROM qdwyc_dd a LEFT JOIN qdwyc_evaluation_score b ON a.dd_num=b.dd_num WHERE a.xc_status=4 and b.ps_type=1
ringa_lee
把a.*和b.*换成各自表里的主键
这样 count 出来的两个值相等不太明白你 count 什么建议先把单独的sql写出了,再优化
COUNT 只能 COUNT(*)、COUNT(字段名),不支持COUNT(别名.*),换成COUNT(`a`.`id`)即可
COUNT(*)
COUNT(字段名)
COUNT(别名.*)
COUNT(`a`.`id`)
你这两句话的COUNT肯定是相等的,估计你想要的结果是,右表在Join为NULL的时候 不计算COUNT吧
第二个COUNT应该是 SUM(IF(`b`.`id` is null, 0, 1))
SUM(IF(`b`.`id` is null, 0, 1))
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
这样 count 出来的两个值相等
不太明白你 count 什么
建议先把单独的sql写出了,再优化
COUNT 只能
COUNT(*)、COUNT(字段名),不支持COUNT(别名.*),换成COUNT(`a`.`id`)即可你这两句话的COUNT肯定是相等的,
估计你想要的结果是,右表在Join为NULL的时候 不计算COUNT吧
第二个COUNT应该是
SUM(IF(`b`.`id` is null, 0, 1))