MySQL GROUP_CONCAT()函数将组中的详解字符串连接成为具有各种选项的单个字符串,也就是详解实现列的合并。
创建一个测试表进行测试
- create table test_classes (std_name varchar(200),详解class_name varchar(200));
- insert into test_classes (std_name , class_name ) value ("小明","二班") , ("小红","二班") ,("小刚","二班"), ("小强","一班"), ("小白","三班") ,("小鱼","三班");
需求:查出三个班级各有什么人,并使用一个字符串的详解字段显示。
这时候直接使用group_concat一个语句就可以直接完成。详解
- select class_name ,详解 group_concat(std_name) As std_names from test_classes group by class_name ;
这里需要根据班级来显示,所以需要使用group_by进行分组
- +------------+----------------------+
- | class_name | std_names |
- +------------+----------------------+
- | 一班 | 小强 |
- | 三班 | 小白,详解小鱼 |
- | 二班 | 小明,小红,小刚 |
- +------------+----------------------+
排序:在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 |
- +------------+----------------------+
- | 一班 | 小强 |
- | 三班 | 小白,小鱼 |
- | 二班 | 小刚,小明,小红 |
- +------------+----------------------+
[[396756]]
去重:可以使用DISTINCT进行去重。
- 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 |
- +------------+----------------------+
- | 一班 | 小强 |
- | 三班 | 小白,小鱼 |
- | 二班 | 小刚,小明,小红 |
- +------------+----------------------+
合并多列:可以配合CONCAT_WS将多列合并成一个字符串。
- select group_concat(CONCAT_WS('的详解',class_name,std_name) SEPARATOR ';') As std_names from test_classes ;
- SEPARATOR 是指定分隔符
- ```sql
- +---------------------------------------------------------------------------------------------------------------------------------+
- | std_names |
- +---------------------------------------------------------------------------------------------------------------------------------+
- | 二班的小明;二班的小红;二班的小刚;一班的小强;三班的小白;三班的小鱼;二班的小明;二班的小明 |
- +---------------------------------------------------------------------------------------------------------------------------------+
GROUP_CONCAT这个函数是有最大长度限制的,如果超过这个长度限制,详解得到的详解字符串就是被截取后的结果,不会报错,详解所以需要注意。
这个是长度是由变量group_concat_max_len控制的。
- show variables like "group_concat_max_len";
可以通过修改这个变量来放大限制。
- SET GLOBAL group_concat_max_len=102400;
- SET SESSION group_concat_max_len=102400;
配置文件就需要在mysqld的配额节进行配置
- [mysqld]
- group_concat_max_len=102400
【编辑推荐】
责任编辑:姜华 来源: 今日头条 MySQL数据库GROUP_CONCAT
(责任编辑:休闲)
华阳股份(600348.SH)公布消息:拟开展应收账款保理业务
深圳纺织服装出口快速增长 前三季度民营企业出口纺织服装333.7亿元
好消息!全国首个百万千瓦煤电机组节能减排升级与改造示范项目建成投产
三峡集团当好能源供应“稳定器” 国内累计新增装机近260万千瓦