mysql 统计join数据的条数
【摘要】 当mysql left join 或者 right join 时,有时候会发现count(*)是无法统计正确数据的主要原因是因为,left 与right join的特性问题例如我需要查询所有有提现记录的会员总数 SELECT * FROM chenrui_users u LEFT JOIN chenrui_money_log as m on m.user_id = u.id WHERE (...
当mysql left join 或者 right join 时,有时候会发现count(*)是无法统计正确数据的
主要原因是因为,left 与right join的特性问题
例如我需要查询所有有提现记录的会员总数
SELECT *
FROM chenrui_users u
LEFT JOIN chenrui_money_log as m on m.user_id = u.id
WHERE ( m.add_time >= '2017-08-27' ) group by user_id
复制
查询结果为
会员总数为49条,如果要增加分页的话,就必须先统计出条数
SELECT count(*)
FROM chenrui_users u
LEFT JOIN chenrui_money_log as m on m.user_id = u.id
WHERE ( m.add_time >= '2017-08-27' ) -- group by user_id 统计时group by需要去除
复制
当这时候统计条数是错误的,将会统计出left join的数据
那该怎么统计这个数据呢?
mysql子查询则可以统计出该结果
select
count(*)
FROM
(
SELECT u.id
FROM chenrui_users u
LEFT JOIN chenrui_money_log as m on m.user_id = u.id
WHERE ( m.add_time >= '2017-08-27' )
group by u.id
)
as a
复制
结果为:
完美解决
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)