[精讚] [會員登入]
7975

[Mysql/Mariadb] GROUP_CONCAT 函數

MySQL 中和 group by 一起用的函式,如果我們要算數值的總和或平均,可以使用 sum() 或 avg() 。但是我們如果要在 group by 中把字串「黏起來」,不是使用 concat(

分享此文連結 //n.sfs.tw/10849

分享連結 [Mysql/Mariadb] GROUP_CONCAT 函數@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2019-10-25 07:35:08 最後編修
2017-03-03 11:24:27 By 張○○
 

自動目錄

MySQL 中和 group by 一起用的函式,如果我們要算數值的總和或平均,可以使用 sum() 或 avg() 。

但是我們如果要在 group by 中把字串「黏起來」,不是使用 concat(),而是使用另一個函式:group_concat()。

GROUP_CONCAT()是MySQL數據庫提供的一個函數,通常跟GROUP BY一起用,可參考MySQL官方文件[1]

以下是官網上的範例和語法:

GROUP_CONCAT([DISTINCT] expr [,expr ...] [ORDER BY {unsigned_integer | col_name | expr} [ASC | DESC] [,col_name ...]] [SEPARATOR str_val])

mysql> SELECT student_name, -> GROUP_CONCAT(test_score) -> FROM student -> GROUP BY student_name;

Or:

mysql> SELECT student_name, -> GROUP_CONCAT(DISTINCT test_score -> ORDER BY test_score DESC SEPARATOR ' ') -> FROM student -> GROUP BY student_name;

以下為注意重點:

1. group_concat 中其實可放另一個SQL的語法。其中,若要排除重覆的值,則加入關鍵字 DISTINCT;若要讓相黏的內容排序,可以在 group_concat 中使用 ORDER BY 關鍵字;而 SEPARATOR 用來作為字串相黏的分隔符號。

2. 如果相黏的字串中有NULL值,他就會回傳NULL值,這裡要特別注意。

3. 產生的值資料型態是 BLOB,他的最大長度是由系統變數  group_concat_max_len 決定,預設是1024bytes;此外有效的最大長度由  max_allowed_packet 系統變數所限制。如果在執行期要修改限制,可使用以下的SQL:

SET [GLOBAL | SESSION] group_concat_max_len = val;

4. 一個使用的範例:

 

簡單的範例

要選擇表單中的村莊名:

SELECT village_name  from `village_table`

然後取完再用迴圈相黏成一個字串,這未免也太麻煩了,所以改成一行寫好,取出來用空白分格,等於選取某欄變字串:

SELECT group_concat(village_name  separator ',' ) from `village_table`

結果

大都城村,辛北庄村,辛南庄村,辛西庄村

這樣就能一次取出一行結果的字串,非常方便。

 

複雜的範例

目的為了呈現多個條件的 SQL 語法。此 SQL 目的是要依供貨商分類取出貨品,並把貨品的流水號產生一個連結的字串 `gdsrec`,並把貨品總價寫成個一值 `sum`

table1: goods 貨品
gsn 流水號
pID 供貨商
price 單價
state 狀態

table2: provider 供貨商
pID 流水號
pname 名稱


關聯 `goods`.`pID`  <-> `provider`.`pID`

SELECT `g`.`pID` , `p`.`pname` , 
group_concat( `g`.`gsn` order by `g`.`gsn` SEPARATOR ',' ) AS `gdsrec` , 
sum( `g`.`price` ) AS `sum`FROM `goods` AS `g` 
LEFT JOIN `provider` AS `p`USING ( `pID` )
WHERE `g`.`state` =1GROUP BY `g`.`pID`
ORDER BY `g`.`pID`LIMIT 0 , 30

結果:

pID pname gdsrec sum
1 河馬公司 94,94,94,259 13947
2 瘦比八企業社 381,381 500
3 張氏企業 734,734,734 36

參考資料

[1] http://dev.mysql.com/doc/refman/5.0/en/group-by-functions.html#function_group-concat


原文 2010-03-01 11:09:35

END

你可能感興趣的文章

[MySQL] console mode 的亂碼處理 使用MySQL的console mode如果出現亂碼 在,要怎麼處理?

[Mysql/MariaDB] 表格的引擎 (engine):查看及修改 MySQL表格引擎預設為 MyISAM,但在4.0以上的mysql 其實支援不只一種引擎,各有優缺點,這篇介紹引擎的操作。

[MariaDB] Centos 7安裝mariadb + apache + php + phpmyadmin Centos 7安裝mariadb+apache+php+phpmyadmin

[Mysql/Mariadb] 密碼設定強度修改 新的mysql對於密碼預設也把原來的規則改得更嚴格,此篇教你修改密碼的設定政策

[Mysql/MariaDB] 查看資料庫所占空間 查看資料庫在磁碟中所占空間

[Mysql] 修改資料庫預設校對或編碼 修改資料庫預設校對或編碼的方法

我有話要說

>>

限制:留言最高字數1000字。 限制:未登入訪客,每則留言間隔需超過10分鐘,每日最多5則留言。

訪客留言

[無留言]

隨機好文

[bc] linux 的計算機 bc 設定小數位數、計算π、次方根 linux 的計算機 bc 設定小數位數、計算π、次方根

[NetBeans] 使用git複製別人的專案 NetBeans使用git複製別人的專案及版本控制

對物品的感情 這個議題很奇怪,可是大部分的人都會有,物品是死的,壞了就淘汰,出新的就被替換。為何會有情感?

讓radio box 或checkbox 好按 在行動裝置下,radio box及checkbox變得很難按得到

兩次使用InnoDB的慘痛經驗 Mysql 的Innodb引擎雖然好用,但是我得說說我兩次的慘痛經驗,這讓我考慮以後可能不會再使用innodb了