首页 > 数据库 > SQL > 正文

SQL中GROUP_CONCAT函数怎么用_GROUP_CONCAT函数合并组数据的教程

爱谁谁
发布: 2025-09-30 17:27:02
原创
741人浏览过
GROUP_CONCAT是MySQL中用于将分组数据合并为字符串的函数,支持排序和自定义分隔符,默认以逗号分隔,常用于如“部门员工列表”场景,仅适用于MySQL,其他数据库可用STRING_AGG等替代,需注意默认1024字符长度限制及NULL值不参与拼接。

sql中group_concat函数怎么用_group_concat函数合并组数据的教程

在SQL中,GROUP_CONCAT 是MySQL提供的一种聚合函数,用于将分组中的多行数据合并为一个字符串。它常用于需要把某个字段的多个值拼接成一行显示的场景,比如查看每个部门的所有员工姓名。

基本语法

GROUP_CONCAT(expression [ORDER BY clause] [SEPARATOR 'sep'])

  • expression:要拼接的字段或表达式
  • ORDER BY(可选):指定拼接顺序
  • SEPARATOR(可选):定义拼接时使用的分隔符,默认是逗号,

简单示例:合并同一组的数据

假设有一张员工表 employees

id name dept
1 张三 技术部
2 李四 技术部
3 王五 销售部

执行以下SQL:

阿里云-虚拟数字人
阿里云-虚拟数字人

阿里云-虚拟数字人是什么? ...

阿里云-虚拟数字人2
查看详情 阿里云-虚拟数字人
SELECT dept, GROUP_CONCAT(name) AS employees FROM employees GROUP BY dept;

结果:

dept employees
技术部 张三,李四
销售部 王五

自定义排序和分隔符

如果希望员工按名字排序,并用分号分隔:

SELECT dept, GROUP_CONCAT(name ORDER BY name SEPARATOR '; ') AS employees FROM employees GROUP BY dept;

输出:

dept employees
技术部 李四; 张三
销售部 王五

注意事项

  • 仅限MySQL:其他数据库如PostgreSQL、SQL Server不支持此函数,对应有 STRING_AGG 等替代方案
  • 长度限制:默认最大拼接长度为1024字符,可通过设置 group_concat_max_len 调整
  • 若字段包含NULL值,NULL不会出现在结果中

基本上就这些。掌握 GROUP_CONCAT 能让你在处理分类汇总数据时更灵活高效。不复杂但容易忽略细节。

以上就是SQL中GROUP_CONCAT函数怎么用_GROUP_CONCAT函数合并组数据的教程的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号