php - mysql連表統(tǒng)計(jì)查詢(xún)
問(wèn)題描述
活動(dòng)表 rehearse id(自增id),name(活動(dòng)名稱(chēng)),send_time(開(kāi)始時(shí)間),uid(創(chuàng)建活動(dòng)的用戶(hù)id)…統(tǒng)計(jì)表 statis id(自增id),mtype(活動(dòng)類(lèi)型1,2,3;1表示 表rehearse內(nèi)的活動(dòng)),sid(來(lái)源id,活動(dòng)表的id),pid(人員id),open_time(打開(kāi)郵件時(shí)間)…
查詢(xún)用戶(hù)id為 6的用戶(hù),創(chuàng)建的活動(dòng)列表(包含信息:活動(dòng)名稱(chēng),開(kāi)始時(shí)間,總郵件數(shù),總打開(kāi)郵件數(shù))open_time>0即為打開(kāi)郵件的記錄,固定條件mtype=1,sid= 通過(guò)uid=6從rehearse查詢(xún)到的活動(dòng)表id。 現(xiàn)在是分開(kāi)查詢(xún)的,然后數(shù)組處理。不知道一條sql怎么查需要的數(shù)據(jù)。求大神幫助
問(wèn)題解答
回答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ì)有效率問(wèn)題,在找更優(yōu)方法
Update方法2:子查詢(xún)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. MySQL數(shù)據(jù)庫(kù)中文亂碼的原因2. dockerfile - 我用docker build的時(shí)候出現(xiàn)下邊問(wèn)題 麻煩幫我看一下3. angular.js - 關(guān)于$apply()4. 如何解決Centos下Docker服務(wù)啟動(dòng)無(wú)響應(yīng),且輸入docker命令無(wú)響應(yīng)?5. nignx - docker內(nèi)nginx 80端口被占用6. mysql - 新浪微博中的關(guān)注功能是如何設(shè)計(jì)表結(jié)構(gòu)的?7. angular.js - Ionic 集成crosswalk后生成的apk在android4.4.2上安裝失?????8. dockerfile - [docker build image失敗- npm install]9. css - C#與java開(kāi)發(fā)Windows程序哪個(gè)好?10. angular.js使用$resource服務(wù)把數(shù)據(jù)存入mongodb的問(wèn)題。
