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. javascript - js setTimeout在雙重for循環中如何使用?2. 求救一下,用新版的phpstudy,數據庫過段時間會消失是什么情況?3. python沒入門,請教一個問題4. javascript - 我的站點貌似被別人克隆了, google 搜索特定文章,除了域名不一樣,其他的都一樣,如何解決?5. html - 爬蟲時出現“DNS lookup failed”,打開網頁卻沒問題,這是什么情況?6. 小程序怎么加外鏈,語句怎么寫!求救新手,開文檔沒發現7. php如何獲取訪問者路由器的mac地址8. javascript - 在 vue里面用import引入js文件,結果為undefined9. html5 - input type=’file’ 上傳獲取的fileList對象怎么存儲于瀏覽器?10. java 線程監控 重啟線程 觀察者模式的問題的問題
