php - mysql連表統(tǒng)計查詢
問題描述
活動表 rehearse id(自增id),name(活動名稱),send_time(開始時間),uid(創(chuàng)建活動的用戶id)…統(tǒng)計表 statis id(自增id),mtype(活動類型1,2,3;1表示 表rehearse內(nèi)的活動),sid(來源id,活動表的id),pid(人員id),open_time(打開郵件時間)…
查詢用戶id為 6的用戶,創(chuàng)建的活動列表(包含信息:活動名稱,開始時間,總郵件數(shù),總打開郵件數(shù))open_time>0即為打開郵件的記錄,固定條件mtype=1,sid= 通過uid=6從rehearse查詢到的活動表id。 現(xiàn)在是分開查詢的,然后數(shù)組處理。不知道一條sql怎么查需要的數(shù)據(jù)。求大神幫助
問題解答
回答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
由于左聯(lián)了兩次,可能會有效率問題,在找更優(yōu)方法
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
相關(guān)文章:
1. redis sentinel怎么跑守護進程以及日志記錄位置的?2. django - Nginx uwsgi 進程問題3. javascript - sublime快鍵鍵問題4. 前端 - 這段代碼一直生效不了,查半天因為 top: 0px; 分號后一個隱藏的東西,也不是占位符...刪了就可以生效,這是什么情況。。5. javascript - 愛加密的HTML5應(yīng)用加固服務(wù)是什么原理?6. 微信小程序支持跳轉(zhuǎn)到外部鏈接網(wǎng)頁嗎7. javascript - 求助關(guān)于js正則問題8. 關(guān)于純用css寫導(dǎo)航鼠標(biāo)移入事件的問題?9. 百度地圖api - Android百度地圖SDK,MapView上層按鈕可見卻不可觸,怎么解決?10. 求救一下,用新版的phpstudy,數(shù)據(jù)庫過段時間會消失是什么情況?

網(wǎng)公網(wǎng)安備