GROUP_CONCAT是MySQL中用于将分组数据合并为字符串的函数,支持排序和自定义分隔符,默认以逗号分隔,常用于如“部门员工列表”场景,仅适用于MySQL,其他数据库可用STRING_AGG等替代,需注意默认1024字符长度限制及NULL值不参与拼接。

在SQL中,GROUP_CONCAT 是MySQL提供的一种聚合函数,用于将分组中的多行数据合并为一个字符串。它常用于需要把某个字段的多个值拼接成一行显示的场景,比如查看每个部门的所有员工姓名。
GROUP_CONCAT(expression [ORDER BY clause] [SEPARATOR 'sep'])
假设有一张员工表 employees:
| id | name | dept |
| 1 | 张三 | 技术部 |
| 2 | 李四 | 技术部 |
| 3 | 王五 | 销售部 |
执行以下SQL:
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 |
| 技术部 | 李四; 张三 |
| 销售部 | 王五 |
基本上就这些。掌握 GROUP_CONCAT 能让你在处理分类汇总数据时更灵活高效。不复杂但容易忽略细节。
以上就是SQL中GROUP_CONCAT函数怎么用_GROUP_CONCAT函数合并组数据的教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号