首页 > 数据库技术 > 详细

GROUP_CONCAT 将mysql多条数据合并为一条

时间:2019-07-05 09:08:28      阅读:116      评论:0      收藏:0      [点我收藏+]

实现将多条数据合并为一条数据,在mysql中可以通过 GROUP_CONCAT 函数实现

技术分享图片

上面是潇leader发我的和工作不相关的小小小需求描述,很明显是要把id和name相同的数据合并为一条,下面按照截图建个demo演示

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------
-- Table structure for demo
-- ----------------------------
DROP TABLE IF EXISTS `demo`;
CREATE TABLE `demo` (
  `id` int(10) DEFAULT NULL,
  `name` varchar(255) DEFAULT NULL,
  `type` varchar(255) DEFAULT NULL,
  `typename` varchar(255) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of demo
-- ----------------------------
INSERT INTO `demo` VALUES (1, aa, t1, ok);
INSERT INTO `demo` VALUES (1, aa, t2, ng);
INSERT INTO `demo` VALUES (1, aa, t3, bug);

实现sql

select id,name,GROUP_CONCAT(CONCAT_WS(,,type,typename) SEPARATOR ,) typelinks from demo GROUP BY id,name;

技术分享图片

拓展一下,演示怎么去重,在GROUP_CONCAT函数中通过对合并字段添加 DISTINCT 约束即可。

技术分享图片

 

GROUP_CONCAT([DISTINCT] expr [,expr ...]
[ORDER BY {unsigned_integer | col_name | formula} [ASC | DESC] [,col ...]]
[SEPARATOR str_val])

上面是GROUP_CONCAT的语法,另外还有几项注意:

  • 使用GROUP_CONCAT 必须要用GROUP BY 语句来进行分组管理,不然所有的数据都会被合并成一条记录。
  • MySQL对于GROUP_CONCAT结果用系统变量group_concat_max_len做了限制,默认值是1024。所以,如果合并有很多列,最好将该值设大一些。

 

GROUP_CONCAT 将mysql多条数据合并为一条

原文:https://www.cnblogs.com/zjfjava/p/11136034.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!