MySQL使用GROUP BY分組查詢
在 MySQL 中,GROUP BY 關(guān)鍵字可以根據(jù)一個或多個字段對查詢結(jié)果進(jìn)行分組。
使用 GROUP BY 關(guān)鍵字的語法格式如下:
GROUP BY <字段名>
其中,“字段名”表示需要分組的字段名稱,多個字段時用逗號隔開。
GROUP BY單獨使用
單獨使用 GROUP BY 關(guān)鍵字時,查詢結(jié)果會只顯示每個分組的第一條記錄。
例 1
下面根據(jù) tb_students_info 表中的 sex 字段進(jìn)行分組查詢,SQL 語句和運(yùn)行結(jié)果如下:
mysql> SELECT `name`,`sex` FROM tb_students_info -> GROUP BY sex; +-------+------+ | name | sex | +-------+------+ | Henry | 女 | | Dany | 男 | +-------+------+ 2 rows in set (0.01 sec)
結(jié)果中只顯示了兩條記錄,這兩條記錄的 sex 字段的值分別為“女”和“男”。
GROUP BY 與 GROUP_CONCAT()
GROUP BY 關(guān)鍵字可以和 GROUP_CONCAT() 函數(shù)一起使用。GROUP_CONCAT() 函數(shù)會把每個分組的字段值都顯示出來。
例 2
下面根據(jù) tb_students_info 表中的 sex 字段進(jìn)行分組查詢,使用 GROUP_CONCAT() 函數(shù)將每個分組的 name 字段的值都顯示出來。SQL 語句和運(yùn)行結(jié)果如下:
mysql> SELECT `sex`, GROUP_CONCAT(name) FROM tb_students_info -> GROUP BY sex; +------+----------------------------+ | sex | GROUP_CONCAT(name) | +------+----------------------------+ | 女 | Henry,Jim,John,Thomas,Tom | | 男 | Dany,Green,Jane,Lily,Susan | +------+----------------------------+ 2 rows in set (0.00 sec)
由結(jié)果可以看到,查詢結(jié)果分為兩組,sex 字段值為“女”的是一組,值為“男”的是一組,且每組的學(xué)生姓名都顯示出來了。
例 3
下面根據(jù) tb_students_info 表中的 age 和 sex 字段進(jìn)行分組查詢。SQL 語句和運(yùn)行結(jié)果如下:
mysql> SELECT age,sex,GROUP_CONCAT(name) FROM tb_students_info -> GROUP BY age,sex; +------+------+--------------------+ | age | sex | GROUP_CONCAT(name) | +------+------+--------------------+ | 21 | 女 | John | | 22 | 女 | Thomas | | 22 | 男 | Jane,Lily | | 23 | 女 | Henry,Tom | | 23 | 男 | Green,Susan | | 24 | 女 | Jim | | 25 | 男 | Dany | +------+------+--------------------+ 7 rows in set (0.00 sec)
上面實例在分組過程中,先按照 age 字段進(jìn)行分組,當(dāng) age 字段值相等時,再把 age 字段值相等的記錄按照 sex 字段進(jìn)行分組。
多個字段分組查詢時,會先按照第一個字段進(jìn)行分組。如果第一個字段中有相同的值,MySQL 才會按照第二個字段進(jìn)行分組。如果第一個字段中的數(shù)據(jù)都是唯一的,那么 MySQL 將不再對第二個字段進(jìn)行分組。
GROUP BY 與聚合函數(shù)
在數(shù)據(jù)統(tǒng)計時,GROUP BY 關(guān)鍵字經(jīng)常和聚合函數(shù)一起使用。
聚合函數(shù)包括 COUNT(),SUM(),AVG(),MAX() 和 MIN()。其中,COUNT() 用來統(tǒng)計記錄的條數(shù);SUM() 用來計算字段值的總和;AVG() 用來計算字段值的平均值;MAX() 用來查詢字段的最大值;MIN() 用來查詢字段的最小值。
例 4
下面根據(jù) tb_students_info 表的 sex 字段進(jìn)行分組查詢,使用 COUNT() 函數(shù)計算每一組的記錄數(shù)。SQL 語句和運(yùn)行結(jié)果如下:
mysql> SELECT sex,COUNT(sex) FROM tb_students_info -> GROUP BY sex; +------+------------+ | sex | COUNT(sex) | +------+------------+ | 女 | 5 | | 男 | 5 | +------+------------+ 2 rows in set (0.00 sec)
結(jié)果顯示,sex 字段值為“女”的記錄是一組,有 5 條記錄;sex 字段值為“男”的記錄是一組,有 5 條記錄。
GROUP BY 與 WITH ROLLUP
WITH POLLUP 關(guān)鍵字用來在所有記錄的最后加上一條記錄,這條記錄是上面所有記錄的總和,即統(tǒng)計記錄數(shù)量。
例 5
下面根據(jù) tb_students_info 表中的 sex 字段進(jìn)行分組查詢,并使用 WITH ROLLUP 顯示記錄的總和。
mysql> SELECT sex,GROUP_CONCAT(name) FROM tb_students_info ->GROUP BY sex WITH ROLLUP; +------+------------------------------------------------------+ | sex | GROUP_CONCAT(name) | +------+------------------------------------------------------+ | 女 | Henry,Jim,John,Thomas,Tom | | 男 | Dany,Green,Jane,Lily,Susan | | NULL | Henry,Jim,John,Thomas,Tom,Dany,Green,Jane,Lily,Susan | +------+------------------------------------------------------+ 3 rows in set (0.00 sec)
查詢結(jié)果顯示,GROUP_CONCAT(name) 顯示了每個分組的 name 字段值。同時,最后一條記錄的 GROUP_CONCAT(name) 字段的值剛好是上面分組 name 字段值的總和。
到此這篇關(guān)于MySQL使用GROUP BY分組查詢的文章就介紹到這了,更多相關(guān)MySQL GROUP BY分組查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySQL運(yùn)行報錯:“Expression?#1?of?SELECT?list?is?not?in?GROUP?BY?clause?and?contains?nonaggre”解決方法
- 解決大于5.7版本mysql的分組報錯Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated
- mysql 8.0 找不到my.ini配置文件以及報sql_mode=only_full_group_by解決方案
- MySQL分組查詢獲取每組最新的一條數(shù)據(jù)詳解(group?by)
- 解決MySQL this is incompatible with sql_mode=only_full_group_by 問題
- MySQL報錯Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggre
相關(guān)文章
Window10下mysql 5.7.21 安裝配置方法圖文教程
這篇文章主要為大家詳細(xì)介紹了Window10下mysql 5.7.21 安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09MySQL中禁止修改數(shù)據(jù)庫表特定列的實現(xiàn)
本文主要介紹了MySQL數(shù)據(jù)庫中使用觸發(fā)器禁止修改特定列,以保護(hù)數(shù)據(jù)的一致性和完整性,下面就來介紹一下,感興趣的可以了解一下2024-12-12mysql5.7.33誤刪除ibdata文件找回數(shù)據(jù)的方法
這篇文章主要介紹了mysql5.7.33誤刪除ibdata文件找回數(shù)據(jù)的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03關(guān)于Mysql中json數(shù)據(jù)類型的查詢操作指南
mysql在5.7版本之后就開始支持json數(shù)據(jù)類型,并且mysql8.0版本對json的處理已經(jīng)做的非常完善了,json數(shù)據(jù)類型的優(yōu)點缺點可自己查詢,本文主要介紹一些關(guān)于json數(shù)據(jù)類型的查詢操作2023-07-07mysql出現(xiàn)ERROR?2003?(HY000):?Can‘t?connect?to?MySQL?ser
本文主要介紹了mysql出現(xiàn)ERROR?2003?(HY000):?Can‘t?connect?to?MySQL?server?on?‘localhost‘?(10061)的解決方法,具有一定的參考價值,感興趣的可以了解一下2025-03-03