MySQL中group_concat函数用法总结

MySQL中group_concat函数用法总结MySQL中group_concat函数用法总结一、group_concat函数的功能将groupby产生的同一个分组中的值连接起来,返回一个字符串结果。group_concat函数首先根据groupby指定的列进行分组,将同一组的列显示出来,并且用分隔符分隔。由函数参数(字段名)决定要返回的列。例如:createtableemp(emp_idintprimaryke…

大家好,又见面了,我是你们的朋友全栈君。

MySQL中group_concat函数用法总结

一、group_concat函数的功能

将group by产生的同一个分组中的值连接起来,返回一个字符串结果。group_concat函数首先根据group by指定的列进行分组,将同一组的列显示出来,并且用分隔符分隔。由函数参数(字段名)决定要返回的列。例如:

create table emp(
    emp_id int primary key auto_increment comment '编号',
    emp_name char(20) not null default '' comment '姓名',
    salary decimal(10,2) not null default 0 comment '工资',
    department char(20) not null default '' comment '部门'
);

insert into emp(emp_name,salary,department) 
values('张晶晶',5000,'财务部'),('王飞飞',5800,'财务部'),('赵刚',6200,'财务部'),('刘小贝',5700,'人事部'),
('王大鹏',6700,'人事部'),('张小斐',5200,'人事部'),('刘云云',7500,'销售部'),('刘云鹏',7200,'销售部'),
('刘云鹏',7800,'销售部');

执行如下查询及结果:

select group_concat(emp_name) from emp;
+----------------------------------------------------------------------------------------+
| group_concat(emp_name)                                                                 |
+----------------------------------------------------------------------------------------+
| 张晶晶,王飞飞,赵刚,刘小贝,王大鹏,张小斐,刘云云,刘云鹏,刘云鹏                           |
+----------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

mysql> select department,group_concat(emp_name) from emp group by department;
+------------+-------------------------------+
| department | group_concat(emp_name)        |
+------------+-------------------------------+
| 人事部     | 刘小贝,王大鹏,张小斐          |
| 财务部     | 张晶晶,王飞飞,赵刚            |
| 销售部     | 刘云云,刘云鹏,刘云鹏          |
+------------+-------------------------------+
3 rows in set (0.00 sec)

二、group_concat函数的语法

group_concat([distinct] 字段名 [order by 排序字段 asc/desc] [separator '分隔符'])

说明:
(1)使用distinct可以排除重复值;
(2)如果需要对结果中的值进行排序,可以使用order by子句;
(3)separator是一个字符串值,默认为逗号。

三、使用举例

group_concat(emp_name):只指定了字段名,销售部有两个同名的也全部显示出来,并且姓名的连接顺序就是表中的记录顺序,连接的分隔符为逗号,结果如下:

mysql> select department,group_concat(emp_name) from emp group by department;
+------------+-------------------------------+
| department | group_concat(emp_name)        |
+------------+-------------------------------+
| 人事部     | 刘小贝,王大鹏,张小斐          |
| 财务部     | 张晶晶,王飞飞,赵刚            |
| 销售部     | 刘云云,刘云鹏,刘云鹏          |
+------------+-------------------------------+
3 rows in set (0.00 sec)

添加了distinct参数,则销售部两个同名的员工只显示一个,结果如下:

select department,group_concat(distinct emp_name) 
from emp group by department;
+------------+---------------------------------+
| department | group_concat(distinct emp_name) |
+------------+---------------------------------+
| 人事部     | 刘小贝,张小斐,王大鹏            |
| 财务部     | 张晶晶,王飞飞,赵刚              |
| 销售部     | 刘云云,刘云鹏                   |
+------------+---------------------------------+
3 rows in set (0.00 sec)

添加了order by参数,表中的记录按salary降序排列,然后再把姓名连接起来,结果如下:

mysql> select department,group_concat(distinct emp_name order by salary desc) 
from emp group by department;
+------------+------------------------------------------------------+
| department | group_concat(distinct emp_name order by salary desc) |
+------------+------------------------------------------------------+
| 人事部     | 王大鹏,刘小贝,张小斐                                 |
| 财务部     | 赵刚,王飞飞,张晶晶                                   |
| 销售部     | 刘云云,刘云鹏                                        |
+------------+------------------------------------------------------+
3 rows in set (0.00 sec)

分隔符修改为@符号,结果如下:

mysql> select department,group_concat(distinct emp_name order by salary desc separator '@') 
from emp group by department;
+------------+--------------------------------------------------------------------+
| department | group_concat(distinct emp_name order by salary desc separator '@') |
+------------+--------------------------------------------------------------------+
| 人事部     | 王大鹏@刘小贝@张小斐                                               |
| 财务部     | 赵刚@王飞飞@张晶晶                                                 |
| 销售部     | 刘云云@刘云鹏                                                      |
+------------+--------------------------------------------------------------------+
3 rows in set (0.00 sec)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137427.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月2日 上午6:16
下一篇 2022年6月2日 上午6:16


相关推荐

  • 数据库备份与恢复方案「建议收藏」

    数据库备份与恢复方案「建议收藏」数据安全性随着计算机的普及和信息技术的进步,特别是计算机网络的飞速发展,信息安全的重要性日趋明显。数据备份是保证信息安全的一个重要方法。只要发生数据传输、数据存储和数据交换,就有可能产生数据故障。这时

    2022年8月4日
    6
  • 软件工程概论题库「建议收藏」

    一、选择题:1.开发软件所需高成本和产品的低质量之间有着尖锐的矛盾,这种现象称做(C)。A.软件工程 B.软件周期 C.软件危机 D.软件产生2.瀑布模型本质上是一种(A)模型。A.线性顺序B.顺序迭代C.线性迭代D.早期产品3.瀑布模型存在的问题是(B)。A.用户容易参与开发 B.缺乏灵活性C.用户与开发者易沟通D.适用可变需求4.螺旋模型是…

    2022年4月17日
    133
  • 深入理解机器学习——基于决策树的模型(一):分类树和回归树

    深入理解机器学习——基于决策树的模型(一):分类树和回归树决策树(DecisionTree)是一种基本的分类与回归方法。本文会讨论决策树中的分类树与回归树,后续文章会继续讨论决策树的Boosting和Bagging的相关方法。决策树由结点和有向边组成。结点有两种类型:内部结点和叶结点,其中内部结点表示一个特征或属性,叶结点表示一个类。分类树分类树是一种描述对实例进行分类的树形结构。用决策树分类,从根结点开始,对实例的某一特征进行测试,根据测…

    2022年6月23日
    44
  • Android获取屏幕宽度高度并动态设置控件宽度,比例等

    Android获取屏幕宽度高度并动态设置控件宽度,比例等

    2021年10月1日
    54
  • Java中ArrayList和LinkedList区别

    Java中ArrayList和LinkedList区别一般大家都知道 ArrayList 和 LinkedList 的大致区别 1 ArrayList 是实现了基于动态数组的数据结构 LinkedList 基于链表的数据结构 2 对于随机访问 get 和 set ArrayList 觉得优于 LinkedList 因为 LinkedList 要移动指针 3 对于新增和删除操作 add 和 remove LinedList 比较占优势 因为

    2025年11月2日
    6
  • nginx 动静分离

    nginx 动静分离Nginx 动静分离简单来说就是把动态跟静态请求分开 不能理解成只是单纯的把动态页面和静态页面物理分离 严格意义上说应该是动态请求跟静态请求分开 可以理解成使用 Nginx 处理静态页面 Tomcat Resin 处理动态页面 动静分离从目前实现角度来讲大致分为两种 把静态文件独立成单独的域名 放在独立的服务器上 也是目前主流推崇的方案 将动态跟静态文件混合在一起发布 通过 nginx 来分开

    2026年3月18日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号