自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

詳解MySQL - group_concat合并列

數(shù)據(jù)庫 MySQL
MySQL GROUP_CONCAT()函數(shù)將組中的字符串連接成為具有各種選項(xiàng)的單個(gè)字符串,也就是實(shí)現(xiàn)列的合并。

 簡介

MySQL GROUP_CONCAT()函數(shù)將組中的字符串連接成為具有各種選項(xiàng)的單個(gè)字符串,也就是實(shí)現(xiàn)列的合并。

測試

創(chuàng)建一個(gè)測試表進(jìn)行測試

  1. create table test_classes (std_name varchar(200),class_name varchar(200)); 
  2.  
  3. insert into test_classes (std_name  , class_name ) value ("小明","二班") , ("小紅","二班") ,("小剛","二班"), ("小強(qiáng)","一班"), ("小白","三班") ,("小魚","三班"); 

 需求:查出三個(gè)班級(jí)各有什么人,并使用一個(gè)字符串的字段顯示。

這時(shí)候直接使用group_concat一個(gè)語句就可以直接完成。

  1. select class_name , group_concat(std_name)  As std_names from test_classes group by class_name ; 

這里需要根據(jù)班級(jí)來顯示,所以需要使用group_by進(jìn)行分組

  1. +------------+----------------------+ 
  2. | class_name | std_names            | 
  3. +------------+----------------------+ 
  4. | 一班       | 小強(qiáng)                 | 
  5. | 三班       | 小白,小魚            | 
  6. | 二班       | 小明,小紅,小剛       | 
  7. +------------+----------------------+ 

 排序:在group_concat也是支持排序的。

  1. select class_name , group_concat(std_name order by std_name)  As std_names from test_classes group by class_name ;   

  1. +------------+----------------------+ 
  2. | class_name | std_names            | 
  3. +------------+----------------------+ 
  4. | 一班       | 小強(qiáng)                 | 
  5. | 三班       | 小白,小魚            | 
  6. | 二班       | 小剛,小明,小紅       | 
  7. +------------+----------------------+ 

 [[396756]]

去重:可以使用DISTINCT進(jìn)行去重。

  1. insert into test_classes (std_name  , class_name ) value ("小明","二班"); 
  2. insert into test_classes (std_name  , class_name ) value ("小明","二班"); 
  3. select class_name , group_concat(DISTINCT(std_name))  As std_names from test_classes group by class_name ;   

  1. +------------+----------------------+ 
  2. | class_name | std_names            | 
  3. +------------+----------------------+ 
  4. | 一班       | 小強(qiáng)                 | 
  5. | 三班       | 小白,小魚            | 
  6. | 二班       | 小剛,小明,小紅       | 
  7. +------------+----------------------+ 

 合并多列:可以配合CONCAT_WS將多列合并成一個(gè)字符串。

  1. select group_concat(CONCAT_WS('的',class_name,std_name) SEPARATOR ';')  As std_names from test_classes ;   
  2.  
  3. SEPARATOR 是指定分隔符 
  4.  
  5. ```sql 
  6. +---------------------------------------------------------------------------------------------------------------------------------+ 
  7. | std_names                                                                                                                       | 
  8. +---------------------------------------------------------------------------------------------------------------------------------+ 
  9. | 二班的小明;二班的小紅;二班的小剛;一班的小強(qiáng);三班的小白;三班的小魚;二班的小明;二班的小明                                         | 
  10. +---------------------------------------------------------------------------------------------------------------------------------+ 

 長度限制

GROUP_CONCAT這個(gè)函數(shù)是有最大長度限制的,如果超過這個(gè)長度限制,得到的字符串就是被截取后的結(jié)果,不會(huì)報(bào)錯(cuò),所以需要注意。

這個(gè)是長度是由變量group_concat_max_len控制的。

  1. show variables like "group_concat_max_len"

可以通過修改這個(gè)變量來放大限制。

  1. SET GLOBAL group_concat_max_len=102400; 
  2. SET SESSION group_concat_max_len=102400; 

 配置文件就需要在mysqld的配額節(jié)進(jìn)行配置

  1. [mysqld] 
  2. group_concat_max_len=102400 

 【編輯推薦】

 

責(zé)任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2010-10-09 15:57:56

MySQL GROUP

2010-05-14 18:16:44

MySQL統(tǒng)計(jì)函數(shù)

2010-06-13 15:00:23

MySQL統(tǒng)計(jì)函數(shù)

2010-10-11 15:28:14

MySQL group

2009-03-25 09:00:11

Group By排序MySQL

2010-10-11 15:08:44

MySQL conca

2010-10-09 14:00:10

mysql CONCA

2010-09-07 11:53:00

SQL語句

2010-10-11 15:21:41

MySQL中conca

2010-10-09 11:54:46

MySQL字符串

2010-10-09 12:01:00

MySQL字符串

2017-01-26 20:48:14

MySQL復(fù)制MySQL程序壓縮

2022-01-17 20:59:37

開發(fā)group by思路

2022-04-26 08:51:29

MySQLgroup by

2009-11-25 10:25:43

PHP數(shù)組合并與拆分

2024-09-13 17:06:54

EF Core分組查詢

2010-05-28 17:15:17

SVN分支與合并

2010-06-01 12:36:04

SVN分支與合并

2023-02-10 07:00:22

2011-03-31 13:51:54

MySQL索引
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)