mysql连表统计查询

活动表 rehearse
id(自增id),name(活动名称),send_time(开始时间),uid(创建活动的用户id)…
统计表 statis
id(自增id),mtype(活动类型1,2,3;1表示 表rehearse内的活动),sid(来源id,活动表的id),pid(人员id),open_time(打开邮件时间)…

查询用户id为 6的用户,创建的活动列表(包含信息:活动名称,开始时间,总邮件数,总打开邮件数)
open_time>0即为打开邮件的记录,固定条件mtype=1,sid= 通过uid=6从rehearse查询到的活动表id。
现在是分开查询的,然后数组处理。
不知道一条sql怎么查需要的数据。求大神帮助

阅读 4.2k
2 个回答
SELECT
    R.name,
    R.send_time,
    COUNT(DISTINCT S1.id) send_times,
    COUNT(DISTINCT S2.id) open_times
FROM rehearse R
LEFT JOIN
    statis S1
ON
    R.id = S1.sid AND S1.mtype = 1
LEFT JOIN
    statis S2
ON
    R.id = S2.sid AND S2.mtype = 1 AND open_time > 0
WHERE
    R.uid = 6
GROUP BY
    R.id

由于左联了两次,可能会有效率问题,在找更优方法

Update

方法2:子查询

SELECT
    R.name,
    R.send_time,
    COUNT(S.id) send_times,
    (SELECT COUNT(S.id) FROM S WHERE AND S.open_time > 0) open_times
FROM
    rehearse R
LEFT JOIN
    (SELECT * FROM statis WHERE mtype = 1 GROUP BY sid, open_time AND sid = R.id) S
SELECT
  r.name,
  r.send_time,
  ifnull(count(s.id), 0) spend_times,
  ifnull(sum(if(s.open_time > 0, 1, 0)), 0) open_times
FROM rehearse r
LEFT JOIN statis s ON r.id = s.sid AND s.mtype = 1
where r.uid=6
group by r.id
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题