mysql如何分組統(tǒng)計(jì)并求出百分比
mysql分組統(tǒng)計(jì)并求出百分比
1、mysql 分組統(tǒng)計(jì)并列出百分比
SELECT ?? ?point_id, ?? ?pname_cn, ?? ?play_num, ?? ?round( play_num / total * 100, 2 ) as `ratio` FROM ?? ?( ?? ?SELECT ?? ??? ?*? ?? ?FROM ?? ??? ?( SELECT? ?? ??? ??? ??? ?ANY_VALUE ( `point_id` ) AS point_id,? ?? ??? ??? ??? ?ANY_VALUE ( `pname_cn` ) AS pname_cn, ? ?? ??? ??? ??? ?sum( `play` ) AS play_num ? ?? ??? ??? ?FROM? ?? ??? ??? ??? ?`dt_collect_antique` WHERE`add_time` BETWEEN '2020-07-02' AND '2020-07-05' ?GROUP BY `point_id` ?) t1 ?? ??? ??? ?INNER JOIN? ?? ??? ??? ?( SELECT? ?? ??? ??? ??? ??? ?sum( `play` ) AS total? ?? ??? ??? ??? ?FROM? ?? ??? ??? ??? ??? ?`dt_collect_antique` WHERE`add_time` BETWEEN '2020-07-02' AND '2020-07-05' ?? ??? ??? ?) t2 ON 1 = 1? ?? ?) t ?? ?? ORDER BY ?? ?`play_num` DESC? ?? ?LIMIT 0, 10;
--查出符合條件并且分組, 統(tǒng)計(jì)出每組數(shù)量
SELECT? ?? ?ANY_VALUE ( `point_id` ) AS point_id,? ?? ?ANY_VALUE ( `pname_cn` ) AS pname_cn, ? ?? ?sum(`like`) as like_num FROM? ?? ?`dt_collect_antique` WHERE`add_time` BETWEEN '2020-07-02' AND '2020-07-05' ?GROUP BY `point_id` ?) t1
--查出符合條件,總數(shù)量
(SELECT? ?? ?sum( `play` ) AS total? FROM? ?? ?`dt_collect_antique` WHERE`add_time` BETWEEN '2020-07-02' AND '2020-07-05' ) t2
2、按年齡段分組,并求個(gè)年齡段占比
SELECT ? ? age_group, ? ? age_total, ? ? round( age_total / total * 100, 2 ) as `ratio` FROM ?? ?( ? ??? ?SELECT ? ? ? ? *? ? ? FROM ? ? ?? ?( SELECT? ? ? ? ??? ??? ?SUM(total) AS age_total, ? ? ? ??? ??? ??? ?CASE ? ? ? ? ? ? ? ? ?? ?WHEN age >= 0 AND age < 18 THEN '18歲以下' ?? ? ? ? ? ? ? ? ? ?WHEN age >= 18 AND age <= 25 THEN '18歲到25歲' ?? ? ? ? ? ? ? ? ? ?WHEN age >= 26 AND age <= 35 THEN '26歲到35歲' ?? ? ? ? ? ? ? ? ? ?WHEN age >= 36 AND age <= 45 THEN '36歲到45歲' ?? ? ? ? ? ? ? ? ? ?WHEN age >= 46 AND age <= 60 THEN '46歲到60歲' ? ? ? ? ? ??? ??? ?ELSE '60歲以上' END ? ? ? ? ? ? ? ? AS age_group FROM dt_collect_age WHERE `add_time` BETWEEN ".$time[0]." AND ".$time[1]." GROUP BY age_group ? ? ?? ?) t1 ? ? ? ? INNER JOIN? ? ? ? ? ?? ?( SELECT? ? ? ? ? ? ??? ??? ?SUM( `total` ) AS total? ? ? ? ? ? ??? ?FROM? ? ? ? ? ? ? ?? ?`dt_collect_age` WHERE `add_time` BETWEEN ".$time[0]." AND ".$time[1]." ? ? ? ? ? ? ) t2 ON 1 = 1? ? ??? ??? ?) t ? ? LIMIT 0, 6;
mysql求百分比的幾種方法
函數(shù)介紹
1、ROUND(X,D)和ROUND(X)
round函數(shù)用于數(shù)據(jù)的四舍五入,x指要處理的數(shù),d是指保留幾位小數(shù)
round(x) ,其實(shí)就是 round(x,0)

d可以是負(fù)數(shù),代表指定小數(shù)點(diǎn)左邊的d位整數(shù)位為0,同時(shí)小數(shù)位均為0

2、FORMAT(X,D)
提供數(shù)據(jù)內(nèi)容格式化功能,可以格式化數(shù)據(jù)為整數(shù)或者浮點(diǎn)數(shù),能四舍五入

D為負(fù)數(shù)時(shí),按0處理

3、LEFT(str,len)
left函數(shù)是一個(gè)字符串函數(shù),它返回具有指定長(zhǎng)度的字符串的左邊部分,str為要處理的字符串,len為長(zhǎng)度

left函數(shù)為字符串截取,不能四舍五入
4、CONCAT(str1,str2,...)
concat函數(shù)用于將多個(gè)字符串連接成一個(gè)字符串

利用round,format,left與concat求百分比



注意:使用left按位截取百分比時(shí),位數(shù)要根據(jù)需要合理設(shè)置,否則容易出現(xiàn)意外BUG

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- MySql如何按照日期進(jìn)行分組統(tǒng)計(jì)
- MySQL按天分組統(tǒng)計(jì)一定時(shí)間內(nèi)的數(shù)據(jù)實(shí)例(沒(méi)有數(shù)據(jù)補(bǔ)0)
- mysql如何分別按年/月/日/周分組統(tǒng)計(jì)數(shù)據(jù)詳解
- mysql實(shí)現(xiàn)按照某個(gè)時(shí)間段分組統(tǒng)計(jì)
- Mysql出生日期轉(zhuǎn)換為年齡并分組統(tǒng)計(jì)人數(shù)的方法示例
- MYSQL每隔10分鐘進(jìn)行分組統(tǒng)計(jì)的實(shí)現(xiàn)方法
- mysql按天/小時(shí)/半小時(shí)/N分鐘/分鐘進(jìn)行數(shù)據(jù)分組統(tǒng)計(jì)功能
相關(guān)文章
mysql分區(qū)表學(xué)習(xí)之日期分區(qū)
這篇文章主要給大家介紹了關(guān)于mysql分區(qū)表學(xué)習(xí)之日期分區(qū)的相關(guān)資料,分區(qū)是一種表的設(shè)計(jì)模式,通俗地講表分區(qū)是將一大表,根據(jù)條件分割成若干個(gè)小表,需要的朋友可以參考下2023-08-08
MySQL如何設(shè)置動(dòng)態(tài)創(chuàng)建時(shí)間(create_time)和修改時(shí)間(update_time)
本文主要介紹了MySQL如何設(shè)置動(dòng)態(tài)創(chuàng)建時(shí)間(create_time)和修改時(shí)間(update_time),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
mysql 5.5 開(kāi)啟慢日志slow log的方法(log_slow_queries)
MySQL中提供了一個(gè)慢查詢(xún)的日志記錄功能,可以把查詢(xún)SQL語(yǔ)句時(shí)間大于多少秒的語(yǔ)句寫(xiě)入慢查詢(xún)?nèi)罩?,日常維護(hù)中可以通過(guò)慢查詢(xún)?nèi)罩镜挠涗浶畔⒖焖贉?zhǔn)確地判斷問(wèn)題所在2016-05-05
MYSQL中統(tǒng)計(jì)查詢(xún)結(jié)果總行數(shù)的便捷方法省去count(*)
查看手冊(cè)后發(fā)現(xiàn)SQL_CALC_FOUND_ROWS關(guān)鍵詞的作用是在查詢(xún)時(shí)統(tǒng)計(jì)滿足過(guò)濾條件后的結(jié)果的總數(shù)(不受 Limit 的限制)具體使用如下,感興趣的朋友可以學(xué)習(xí)下2013-07-07
MySQL實(shí)現(xiàn)數(shù)據(jù)批量更新功能詳解
最近需要批量更新大量數(shù)據(jù),習(xí)慣了寫(xiě)sql,所以還是用sql來(lái)實(shí)現(xiàn),下面這篇文章主要給大家總結(jié)介紹了關(guān)于MySQL批量更新的方式,需要的朋友可以參考下2023-02-02
MySQL性能優(yōu)化之Open_Table配置參數(shù)的合理配置建議
這篇文章主要介紹了MySQL性能優(yōu)化之Open_Table配置參數(shù)的合理配置建議,在MySQL數(shù)據(jù)庫(kù)中,Opened_tables表示打開(kāi)過(guò)的表數(shù)量,需要的朋友可以參考下2014-07-07
SQL函數(shù)實(shí)現(xiàn)Group_concat用法
GROUP_CONCAT用于將每個(gè)分組內(nèi)的值連接成一個(gè)字符串,并通過(guò)指定的分隔符進(jìn)行分隔,本文主要介紹了SQL函數(shù)實(shí)現(xiàn)Group_concat用法,具有一定的參考價(jià)值,感興趣的可以了解一下2024-08-08
mysql創(chuàng)建學(xué)生表、課程表及學(xué)生選課表詳細(xì)代碼
這篇文章主要給大家介紹了mysql創(chuàng)建學(xué)生表、課程表及學(xué)生選課表的相關(guān)資料,學(xué)生、課程以及成績(jī)的增刪改查都是建立在連接數(shù)據(jù)庫(kù)的基礎(chǔ)之上,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12

