php - mysql連表統(tǒng)計(jì)查詢
問題描述
活動(dòng)表 rehearse id(自增id),name(活動(dòng)名稱),send_time(開始時(shí)間),uid(創(chuàng)建活動(dòng)的用戶id)…統(tǒng)計(jì)表 statis id(自增id),mtype(活動(dòng)類型1,2,3;1表示 表rehearse內(nèi)的活動(dòng)),sid(來源id,活動(dòng)表的id),pid(人員id),open_time(打開郵件時(shí)間)…
查詢用戶id為 6的用戶,創(chuàng)建的活動(dòng)列表(包含信息:活動(dòng)名稱,開始時(shí)間,總郵件數(shù),總打開郵件數(shù))open_time>0即為打開郵件的記錄,固定條件mtype=1,sid= 通過uid=6從rehearse查詢到的活動(dòng)表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)了兩次,可能會(huì)有效率問題,在找更優(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. angular.js - webpack build后的angularjs路由跳轉(zhuǎn)問題2. java - Activity中的成員變量被賦值之后,Activity被回收的時(shí)候內(nèi)存才會(huì)被釋放嗎3. java - web項(xiàng)目中,用戶登陸信息存儲(chǔ)在session中好 還是cookie中好,取決于什么?4. 數(shù)組按鍵值封裝!5. 為什么bindClass訪問不了的?6. php由5.3升級(jí)到5.6后,登錄網(wǎng)站,返回的是php代碼,不是登錄界面,各位大神有知道的嗎?7. 單擊登錄按鈕無反應(yīng)8. 請(qǐng)求一個(gè)數(shù)據(jù)返回內(nèi)容為空或者錯(cuò)誤如何再次請(qǐng)求幾次9. 這個(gè)是什么問題?10. 為什么 必須在<ul> 下建立 <li> 在建<a>?
