这篇文章给大家介绍MySQL中怎么使用group_concat合并列,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

测试

创建一个测试表进行测试

createtabletest_classes(std_namevarchar(200),class_namevarchar(200));insertintotest_classes(std_name,class_name)value("小明","二班"),("小红","二班"),("小刚","二班"),("小强","一班"),("小白","三班"),("小鱼","三班");

需求:查出三个班级各有什么人,并使用一个字符串的字段显示。

这时候直接使用group_concat一个语句就可以直接完成。

selectclass_name,group_concat(std_name)Asstd_namesfromtest_classesgroupbyclass_name;

这里需要根据班级来显示,所以需要使用group_by进行分组

+------------+----------------------+|class_name|std_names|+------------+----------------------+|一班|小强||三班|小白,小鱼||二班|小明,小红,小刚|+------------+----------------------+

排序:在group_concat也是支持排序的。

selectclass_name,group_concat(std_nameorderbystd_name)Asstd_namesfromtest_classesgroupbyclass_name;


+------------+----------------------+|class_name|std_names|+------------+----------------------+|一班|小强||三班|小白,小鱼||二班|小刚,小明,小红|+------------+----------------------+

去重:可以使用DISTINCT进行去重。

insertintotest_classes(std_name,class_name)value("小明","二班");

insertintotest_classes(std_name,class_name)value("小明","二班");

selectclass_name,group_concat(DISTINCT(std_name))Asstd_namesfromtest_classesgroupbyclass_name;


+------------+----------------------+|class_name|std_names|+------------+----------------------+|一班|小强||三班|小白,小鱼||二班|小刚,小明,小红|+------------+----------------------+

合并多列:可以配合CONCAT_WS将多列合并成一个字符串。

selectgroup_concat(CONCAT_WS('的',class_name,std_name)SEPARATOR';')Asstd_namesfromtest_classes;SEPARATOR是指定分隔符```sql+---------------------------------------------------------------------------------------------------------------------------------+|std_names|+---------------------------------------------------------------------------------------------------------------------------------+|二班的小明;二班的小红;二班的小刚;一班的小强;三班的小白;三班的小鱼;二班的小明;二班的小明|+---------------------------------------------------------------------------------------------------------------------------------+长度限制

GROUP_CONCAT这个函数是有最大长度限制的,如果超过这个长度限制,得到的字符串就是被截取后的结果,不会报错,所以需要注意。

这个是长度是由变量group_concat_max_len控制的。

showvariableslike"group_concat_max_len";

可以通过修改这个变量来放大限制。

SETGLOBALgroup_concat_max_len=102400;SETSESSIONgroup_concat_max_len=102400;

配置文件就需要在mysqld的配额节进行配置

[mysqld]group_concat_max_len=102400

关于MySQL中怎么使用group_concat合并列就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。