您现在的位置是:亿华云 > 应用开发
详解MySQL - group_concat合并列
亿华云2025-10-09 09:06:23【应用开发】4人已围观
简介简介MySQL GROUP_CONCAT()函数将组中的字符串连接成为具有各种选项的单个字符串,也就是实现列的合并。测试创建一个测试表进行测试createtabletest_classes(std_n
简介
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【编辑推荐】
为写论文向Linux提交「恶意代码」,结果整个大学都被Linux封了 Python中那些神一样的算法 自从上了SkyWalking,睡觉真香!!! 熬了三个晚上总结的Python 200个标准库!建议收藏 到底什么是MySQL执行计划吗?亿华云计算很赞哦!(79281)
热门文章
站长推荐
用户邮箱的静态密码可能已被钓鱼和同一密码泄露。在没有收到安全警报的情况下,用户在适当的时间内不能更改密码。在此期间,攻击者可以随意输入帐户。启用辅助身份验证后,如果攻击者无法获取移动电话动态密码,他将无法进行身份验证。这样,除非用户的电子邮件密码和手机同时被盗,否则攻击者很难破解用户的邮箱。
详解Oracle数据库分布式事务ORA-01591错误解决方法
图文并茂:Zookeeper分布式锁原理
为什么处理排序数组比未排序数组快
当投资者经过第二阶段的认真学习之后又充满了信心,认为自己可以在市场上叱咤风云地大干一场了。但没想到“看花容易绣花难”,由于对理论知识不会灵活运用.从而失去灵活应变的本能,就经常会出现小赢大亏的局面,结果往往仍以失败告终。这使投资者很是困惑和痛苦,不知该如何办,甚至开始怀疑这个市场是不是不适合自己。在这种情况下,有的人选择了放弃,但有的意志坚定者则决定做最后的尝试。
敦煌·刘积仁畅谈融合时代的东软!
注册域名需要什么技巧
基于MVCC,我用C++自己手撸了个MySQL!