【紧急】【Mysql】为什么多次leftjoin后使用聚合函数count统计数据就不准确了呢??跪求大神指点!

先上sql

SELECT
    a.id venueId,
    a.venue_name,
    a. STATUS venueStatus,
    COUNT(b.id) venueCourseCount
FROM
    t_venue a
LEFT JOIN t_venue_course b ON b.venue_id = a.id
GROUP BY
    a.id;

只有a和b进行左外连接 查出来的数据是

图片描述

如图所示,这是可以看到venueId为4的venueCourseCount为10

然后我改一下sql

SELECT
    a.id venueId,
    a.venue_name,
    a. STATUS venueStatus,
    COUNT(b.id) venueCourseCount
FROM
    t_venue a
LEFT JOIN t_venue_course b ON b.venue_id = a.id
LEFT JOIN t_course_info c ON c.venue_course_id = b.id
GROUP BY
    a.id;

图片描述

这时 b表和c表又进行一次左外连接,但是venueId为4的venueCourseCount变成16了 这是什么情况,我都groupby分组了啊 求大神搭救

阅读 13.7k
1 个回答

因为第二个条件并不是一对一,这是唯一的解释,如果有必要可以在count里面使用distint或者增加第二个表的join条件,保证三个表记录的一对一。

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