詳解MySQL - group_concat合并列
簡介
MySQL GROUP_CONCAT()函數(shù)將組中的字符串連接成為具有各種選項(xiàng)的單個(gè)字符串,也就是實(shí)現(xiàn)列的合并。
測試
創(chuàng)建一個(gè)測試表進(jìn)行測試
- create table test_classes (std_name varchar(200),class_name varchar(200));
- insert into test_classes (std_name , class_name ) value ("小明","二班") , ("小紅","二班") ,("小剛","二班"), ("小強(qiáng)","一班"), ("小白","三班") ,("小魚","三班");
需求:查出三個(gè)班級(jí)各有什么人,并使用一個(gè)字符串的字段顯示。
這時(shí)候直接使用group_concat一個(gè)語句就可以直接完成。
- select class_name , group_concat(std_name) As std_names from test_classes group by class_name ;
這里需要根據(jù)班級(jí)來顯示,所以需要使用group_by進(jìn)行分組
- +------------+----------------------+
- | class_name | std_names |
- +------------+----------------------+
- | 一班 | 小強(qiáng) |
- | 三班 | 小白,小魚 |
- | 二班 | 小明,小紅,小剛 |
- +------------+----------------------+
排序:在group_concat也是支持排序的。
- select class_name , group_concat(std_name order by std_name) As std_names from test_classes group by class_name ;
- +------------+----------------------+
- | class_name | std_names |
- +------------+----------------------+
- | 一班 | 小強(qiáng) |
- | 三班 | 小白,小魚 |
- | 二班 | 小剛,小明,小紅 |
- +------------+----------------------+
去重:可以使用DISTINCT進(jìn)行去重。
- insert into test_classes (std_name , class_name ) value ("小明","二班");
- insert into test_classes (std_name , class_name ) value ("小明","二班");
- select class_name , group_concat(DISTINCT(std_name)) As std_names from test_classes group by class_name ;
- +------------+----------------------+
- | class_name | std_names |
- +------------+----------------------+
- | 一班 | 小強(qiáng) |
- | 三班 | 小白,小魚 |
- | 二班 | 小剛,小明,小紅 |
- +------------+----------------------+
合并多列:可以配合CONCAT_WS將多列合并成一個(gè)字符串。
- select group_concat(CONCAT_WS('的',class_name,std_name) SEPARATOR ';') As std_names from test_classes ;
- SEPARATOR 是指定分隔符
- ```sql
- +---------------------------------------------------------------------------------------------------------------------------------+
- | std_names |
- +---------------------------------------------------------------------------------------------------------------------------------+
- | 二班的小明;二班的小紅;二班的小剛;一班的小強(qiáng);三班的小白;三班的小魚;二班的小明;二班的小明 |
- +---------------------------------------------------------------------------------------------------------------------------------+
長度限制
GROUP_CONCAT這個(gè)函數(shù)是有最大長度限制的,如果超過這個(gè)長度限制,得到的字符串就是被截取后的結(jié)果,不會(huì)報(bào)錯(cuò),所以需要注意。
這個(gè)是長度是由變量group_concat_max_len控制的。
- show variables like "group_concat_max_len";
可以通過修改這個(gè)變量來放大限制。
- SET GLOBAL group_concat_max_len=102400;
- SET SESSION group_concat_max_len=102400;
配置文件就需要在mysqld的配額節(jié)進(jìn)行配置
- [mysqld]
- group_concat_max_len=102400
【編輯推薦】