一、實現需求
最近在做成就系統,成就中有很多維度都和數量有關,比如用戶粉絲數達到多少50個,授予 名揚四海 稱號,用戶點贊達到 100 次,授予 點贊圣手 稱號等等。
粉絲數在 user_relation
表
點贊數在 user_praise
表
按照以往的做法,如果需要查詢用戶的這些數據,又因為數據是在不同的表中,所以往往會分開多條 SQL 查詢,比如:
SELECT count(*) mysh FROM user_relation WHERE other_uid =123456;
SELECT count(*) dzss FROM user_praise WHERE praise_uid = 123456;
然后將查詢出的數據封裝在一個對象中,返回給客戶端或者另做他用,如果需要統計的表少點還可以,但是像成就系統中,往往有各種各樣的成就,我們現在涉及到 12 張表,如果按照這種來查詢,那么就要寫 12 條 SQL 查詢 12 次,這讓人有點不爽。
二、能否用一條 SQL 語句實現呢
答案是肯定的
像這種將多個表不同的數據,整合在一個表中的時候,我們可以采用 UNION
操作。
首先將使用 UNION
改寫以上語句:
SELECT wrzm,mysh,sgbh FROM (
SELECT count(*) wrzm,0 mysh,0 sgbh FROM user_witness WHERE plan_uid = 123456
UNION ALL
SELECT 0 wrzm,count(*) mysh,0 sgbh FROM user_relation WHERE other_uid = 123456
UNION ALL
SELECT 0 wrzm,0 mysh,count(*) sgbh FROM plan_stage WHERE uid = 123456 AND status = 1
) t;
按照上面查詢出來的結果為:

mysql_count_results
我們發現這個結果已經有點像樣了,如果能將表中 wrzm
,mysh
,sgbh
的數據三行變成一行,那就好了。于是我們很自然可以想到用 SUM
(當然一開始我沒想到,經過朋友提醒),于是改寫上面的 SQL :
SELECT sum(wrzm) wrzm,sum(mysh) mysh,sum(sgbh) sgbh FROM (
SELECT count(*) wrzm,0 mysh,0 sgbh FROM user_witness WHERE plan_uid = 123456
UNION ALL
SELECT 0 wrzm,count(*) mysh,0 sgbh FROM user_relation WHERE other_uid = 123456
UNION ALL
SELECT 0 wrzm,0 mysh,count(*) sgbh FROM plan_stage WHERE uid = 123456 AND status = 1
) t;
然后得出的結果為:

mysql_count_result_2
至此,得到了我們想要的結果,在一條 SQL 語句中實現了多個表的 count
統計。
三、拓展
如圖,我們能獲取到的僅僅是一個用戶的數據,但是我們需要統計的是 user_info
中的所有用戶,那么也很簡單,我們再次進行改寫:
SELECT uid,sum(wrzm) wrzm,sum(mysh) mysh,sum(sgbh) sgbh FROM (
SELECT plan_uid uid,count(*) wrzm,0 mysh,0 sgbh FROM user_witness
GROUP BY plan_uid
UNION ALL
SELECT other_uid uid,0 wrzm,count(*) mysh,0 sgbh FROM user_relation
GROUP BY other_uid
UNION ALL
SELECT uid,0 wrzm,0 mysh,count(*) sgbh FROM plan_stage WHERE status = 1
GROUP BY uid
) t GROUP BY uid;
查詢結果為:

mysql_count_results_3
在這個結果中,如果我們需要查看具體某一個用戶,那么在最后加上
WHERE uid = 123456
即可,如果要排序的話,那么直接加上 ORDER BY
即可。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家在使用或者學習mysql的時候能有所幫助,如果有疑問大家可以留言交流。
您可能感興趣的文章:- MySQL 大表的count()優化實現
- MySQL中聚合函數count的使用和性能優化技巧
- 關于mysql中innodb的count優化問題分享
- 聊聊MySQL的COUNT(*)的性能
- 詳解 MySQL中count函數的正確使用方法
- 淺談MySQL 統計行數的 count
- mysql count提高方法總結
- MySQL中無過濾條件的count詳解
- MySQL中count(*)、count(1)和count(col)的區別匯總
- MySQL COUNT函數的使用與優化