当前位置:首页 >焦点 >详解MySQL 也就是详解实现列的合并

详解MySQL 也就是详解实现列的合并

2024-06-29 07:08:57 [百科] 来源:避面尹邢网

详解MySQL - group_concat合并列

作者:linux运维菜 数据库 MySQL MySQL GROUP_CONCAT()函数将组中的详解字符串连接成为具有各种选项的单个字符串,也就是详解实现列的合并。

 简介

MySQL GROUP_CONCAT()函数将组中的详解字符串连接成为具有各种选项的单个字符串,也就是详解实现列的合并。

详解MySQL 也就是详解实现列的合并

测试

创建一个测试表进行测试

详解MySQL 也就是详解实现列的合并

  1. create table test_classes (std_name varchar(200),详解class_name varchar(200)); 
  2.  
  3. insert into test_classes (std_name  , class_name ) value ("小明","二班") , ("小红","二班") ,("小刚","二班"), ("小强","一班"), ("小白","三班") ,("小鱼","三班"); 

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

详解MySQL 也就是详解实现列的合并

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

  1. select class_name ,详解 group_concat(std_name)  As std_names from test_classes group by class_name ; 

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

  1. +------------+----------------------+ 
  2. | class_name | std_names            | 
  3. +------------+----------------------+ 
  4. | 一班       | 小强                 | 
  5. | 三班       | 小白,详解小鱼            | 
  6. | 二班       | 小明,小红,小刚       | 
  7. +------------+----------------------+ 

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

  1. select class_name ,详解 group_concat(std_name order by std_name)  As std_names from test_classes group by class_name ;   

  1. +------------+----------------------+ 
  2. | class_name | std_names            | 
  3. +------------+----------------------+ 
  4. | 一班       | 小强                 | 
  5. | 三班       | 小白,小鱼            | 
  6. | 二班       | 小刚,小明,小红       | 
  7. +------------+----------------------+ 

 [[396756]]

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

  1. insert into test_classes (std_name  ,详解 class_name ) value ("小明","二班"); 
  2. insert into test_classes (std_name  , class_name ) value ("小明","二班"); 
  3. select class_name , group_concat(DISTINCT(std_name))  As std_names from test_classes group by class_name ;   

  1. +------------+----------------------+ 
  2. | class_name | std_names            | 
  3. +------------+----------------------+ 
  4. | 一班       | 小强                 | 
  5. | 三班       | 小白,小鱼            | 
  6. | 二班       | 小刚,小明,小红       | 
  7. +------------+----------------------+ 

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

  1. select group_concat(CONCAT_WS('的详解',class_name,std_name) SEPARATOR ';')  As std_names from test_classes ;   
  2.  
  3. SEPARATOR 是指定分隔符 
  4.  
  5. ```sql 
  6. +---------------------------------------------------------------------------------------------------------------------------------+ 
  7. | std_names                                                                                                                       | 
  8. +---------------------------------------------------------------------------------------------------------------------------------+ 
  9. | 二班的小明;二班的小红;二班的小刚;一班的小强;三班的小白;三班的小鱼;二班的小明;二班的小明                                         | 
  10. +---------------------------------------------------------------------------------------------------------------------------------+ 

 长度限制

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

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

  1. show variables like "group_concat_max_len"; 

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

  1. SET GLOBAL group_concat_max_len=102400; 
  2. SET SESSION group_concat_max_len=102400; 

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

  1. [mysqld] 
  2. group_concat_max_len=102400 

 【编辑推荐】

  1. 为写论文向Linux提交「恶意代码」,结果整个大学都被Linux封了
  2. Python中那些神一样的算法
  3. 自从上了SkyWalking,睡觉真香!!!
  4. 熬了三个晚上总结的Python 200个标准库!建议收藏
  5. 到底什么是MySQL执行计划吗?

 

责任编辑:姜华 来源: 今日头条 MySQL数据库GROUP_CONCAT

(责任编辑:休闲)

    推荐文章
    热点阅读