久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

php - mysql連表統計查詢

瀏覽:124日期:2022-06-11 09:05:55

問題描述

活動表 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

相關文章:
主站蜘蛛池模板: 类乌齐县| 汾阳市| 明水县| 莆田市| 贡嘎县| 神木县| 安多县| 当阳市| 四子王旗| 宁陕县| 固镇县| 思茅市| 鹤壁市| 东丽区| 延长县| 凌云县| 游戏| 喜德县| 嘉义市| 手机| 临湘市| 白玉县| 天水市| 张家口市| 弋阳县| 黄冈市| 阳山县| 英山县| 武平县| 泗洪县| 颍上县| 西丰县| 平罗县| 贵阳市| 会昌县| 江口县| 海安县| 台中县| 安阳县| 礼泉县| 长海县|