2022-10-27 398
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
原文链接:https://77isp.com/post/10371.html
=========================================
https://77isp.com/ 为 “云服务器技术网” 唯一官方服务平台,请勿相信其他任何渠道。
数据库技术 2022-03-28
网站技术 2022-11-26
网站技术 2023-01-07
网站技术 2022-11-17
Windows相关 2022-02-23
网站技术 2023-01-14
Windows相关 2022-02-16
Windows相关 2022-02-16
Linux相关 2022-02-27
数据库技术 2022-02-20
抠敌 2023年10月23日
嚼餐 2023年10月23日
男忌 2023年10月22日
瓮仆 2023年10月22日
簿偌 2023年10月22日
扫码二维码
获取最新动态