《MYSQL數(shù)據(jù)庫mySQL count多個(gè)表的數(shù)據(jù)實(shí)例詳解》要點(diǎn):
本文介紹了MYSQL數(shù)據(jù)庫mySQL count多個(gè)表的數(shù)據(jù)實(shí)例詳解,希望對您有用。如果有疑問,可以聯(lián)系我們。
MYSQL應(yīng)用一、實(shí)現(xiàn)需求
MYSQL應(yīng)用最近在做成就系統(tǒng),成就中有很多維度都和數(shù)量有關(guān),比如用戶粉絲數(shù)達(dá)到多少50個(gè),授予 名揚(yáng)四海 稱號,用戶點(diǎn)贊達(dá)到 100 次,授予 點(diǎn)贊圣手 稱號等等.
MYSQL應(yīng)用粉絲數(shù)在 user_relation
表
MYSQL應(yīng)用點(diǎn)贊數(shù)在 user_praise
表
MYSQL應(yīng)用按照以往的做法,如果需要查詢用戶的這些數(shù)據(jù),又因?yàn)閿?shù)據(jù)是在不同的表中,所以往往會分開多條 SQL 查詢,比如:
MYSQL應(yīng)用
SELECT count(*) mysh FROM user_relation WHERE other_uid =123456;
MYSQL應(yīng)用
SELECT count(*) dzss FROM user_praise WHERE praise_uid = 123456;
MYSQL應(yīng)用然后將查詢出的數(shù)據(jù)封裝在一個(gè)對象中,返回給客戶端或者另做他用,如果需要統(tǒng)計(jì)的表少點(diǎn)還可以,但是像成就系統(tǒng)中,往往有各種各樣的成就,我們現(xiàn)在涉及到 12 張表,如果按照這種來查詢,那么就要寫 12 條 SQL 查詢 12 次,這讓人有點(diǎn)不爽.
MYSQL應(yīng)用二、能否用一條 SQL 語句實(shí)現(xiàn)呢
MYSQL應(yīng)用答案是肯定的
MYSQL應(yīng)用像這種將多個(gè)表不同的數(shù)據(jù),整合在一個(gè)表中的時(shí)候,我們可以采用 UNION
操作.
MYSQL應(yīng)用首先將使用 UNION
改寫以上語句:
MYSQL應(yīng)用
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應(yīng)用按照上面查詢出來的結(jié)果為:
MYSQL應(yīng)用
mysql_count_results
MYSQL應(yīng)用我們發(fā)現(xiàn)這個(gè)結(jié)果已經(jīng)有點(diǎn)像樣了,如果能將表中 wrzm
,mysh
,sgbh
的數(shù)據(jù)三行變成一行,那就好了.于是我們很自然可以想到用 SUM
(當(dāng)然一開始我沒想到,經(jīng)過朋友提醒),于是改寫上面的 SQL :
MYSQL應(yīng)用
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應(yīng)用然后得出的結(jié)果為:
MYSQL應(yīng)用
mysql_count_result_2
MYSQL應(yīng)用至此,得到了我們想要的結(jié)果,在一條 SQL 語句中實(shí)現(xiàn)了多個(gè)表的 count
統(tǒng)計(jì).
MYSQL應(yīng)用三、拓展
MYSQL應(yīng)用如圖,我們能獲取到的僅僅是一個(gè)用戶的數(shù)據(jù),但是我們需要統(tǒng)計(jì)的是 user_info
中的所有用戶,那么也很簡單,我們再次進(jìn)行改寫:
MYSQL應(yīng)用
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應(yīng)用查詢結(jié)果為:
MYSQL應(yīng)用
mysql_count_results_3
MYSQL應(yīng)用在這個(gè)結(jié)果中,如果我們需要查看具體某一個(gè)用戶,那么在最后加上WHERE uid = 123456
即可,如果要排序的話,那么直接加上 ORDER BY
即可.
MYSQL應(yīng)用總結(jié)
MYSQL應(yīng)用以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家在使用或者學(xué)習(xí)mysql的時(shí)候能有所幫助,如果有疑問大家可以留言交流.
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/2105.html