这篇文章给大家介绍Mysql中怎么使用group_concat合并列,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。测试创建一个测试表进行测试create table 
这篇文章给大家介绍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 | +------------+----------------------+ | 一班 | 小强 | | 三班 | 小白,小鱼 | | 二班 | 小刚,小明,小红 | +------------+----------------------+
去重:可以使用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合并列就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
--结束END--
本文标题: MySQL中怎么使用group_concat合并列
本文链接: https://lsjlt.com/news/56967.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-23
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0