MySQL的合计函数这里为什么报错?

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

阅读 2.4k
3 个回答
把a.*和b.*换成各自表里的主键
新手上路,请多包涵

这样 count 出来的两个值相等
不太明白你 count 什么
建议先把单独的sql写出了,再优化

  • COUNT 只能 COUNT(*)COUNT(字段名),不支持COUNT(别名.*),换成COUNT(`a`.`id`)即可

  • 你这两句话的COUNT肯定是相等的,
    估计你想要的结果是,右表在Join为NULL的时候 不计算COUNT吧

  • 第二个COUNT应该是 SUM(IF(`b`.`id` is null, 0, 1))

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题