号外号外: 原[图享网]更名为 码友网(codedefault.com) 啦,感谢大家一路上的陪伴与支持。代码的世界里,码友网与大家一起同行!

MySQL使用GROUP_CONCAT()函数按ID分组将多条记录的某个字段以逗号或者指定分隔号隔开成一条记录

MySQL 作者: Rector 29904阅读 0评论 0收藏 收藏本文

郑重申明:本文未经许可,禁止任何形式转载

mysql-logo 这篇文章的标题看上去不太对。想用一句话概括这篇文章想表达的内容,太难起了。不管了,我们用一个具体的应用场景来解释一下这句话所要真正表达的SQL查询思想,假如我有如下需求,有数据表如下:
id    Name
1          A
1          B
2          C
想用一条SQL语句查询得到如下结果:
id    Names
1     A,B
2     C
以上的需求场景即为本文的主题,有了MySQL的查询数据和需求,那么我们怎么样用一句MYSQL来实现呢,代码如下:
SELECT Id, GROUP_CONCAT(Name SEPARATOR ',') Names FROM some_table GROUP BY id
其中GROUP_CONCAT()函数的分隔符可以自定义,根据你的需求适当选择即可,完整的测试用例:
CREATE TABLE `USERS`(
`Id` INT(4) NOT NULL,
`Name` VARCHAR(30) DEFAULT ''
);
INSERT INTO USERS(`Id`,`Name`) VALUES(1,'A'),(1,'B'),(2,'C');
SELECT Id,GROUP_CONCAT(`Name` SEPARATOR ',') NAMES FROM `USERS` GROUP BY Id;
如果你的字段字节数据较多,则可以使用如下语句来设置group_concat的最大字节数:
SET group_concat_max_len = 20480000;

阅读了该文章的人还浏览了...

本文永久链接码友网 » MySQL使用GROUP_CONCAT()函数按ID分组将多条记录的某个字段以逗号或者指定分隔号隔开成一条记录

发布于: 2014-08-27 12:40:24
分享扩散:

文章评论

获取验证码