php - 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怎么查需要的数据。求大神帮助
问题解答
回答1:SELECT R.name, R.send_time, COUNT(DISTINCT S1.id) send_times, COUNT(DISTINCT S2.id) open_timesFROM rehearse RLEFT JOIN statis S1ON R.id = S1.sid AND S1.mtype = 1LEFT JOIN statis S2ON R.id = S2.sid AND S2.mtype = 1 AND open_time > 0WHERE R.uid = 6GROUP 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_timesFROM rehearse RLEFT JOIN (SELECT * FROM statis WHERE mtype = 1 GROUP BY sid, open_time AND sid = R.id) S
相关文章:
1. MYSQL 根据两个字段值查询 但两个值的位置可能是互换的,这个怎么查?2. 求救一下,用新版的phpstudy,数据库过段时间会消失是什么情况?3. mysql replace 死锁4. mysql - C#连接数据库时一直这一句出问题int i = cmd.ExecuteNonQuery();5. javascript - 微信网页开发从菜单进入页面后,按返回键没有关闭浏览器而是刷新当前页面,求解决?6. extra没有加载出来7. android - 安卓做前端,PHP做后台服务器 有什么需要注意的?8. python - 数据与循环次数对应不上9. php传对应的id值为什么传不了啊有木有大神会的看我下方截图10. mysql - ubuntu开启3306端口失败,有什么办法可以解决?
