GROUP_CONCAT 將mysql多條數據合並為一條


實現將多條數據合並為一條數據,在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。所以,如果合並有很多列,最好將該值設大一些。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM