溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL中怎么使用group_concat合并列

發(fā)布時(shí)間:2021-07-26 16:08:26 來(lái)源:億速云 閱讀:178 作者:Leah 欄目:數(shù)據(jù)庫(kù)

這篇文章給大家介紹MySQL中怎么使用group_concat合并列,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

測(cè)試

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

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

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

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

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

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

+------------+----------------------+ | class_name | std_names            | +------------+----------------------+ | 一班       | 小強(qiáng)                 | | 三班       | 小白,小魚            | | 二班       | 小明,小紅,小剛       | +------------+----------------------+

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

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


+------------+----------------------+ | class_name | std_names            | +------------+----------------------+ | 一班       | 小強(qiáng)                 | | 三班       | 小白,小魚            | | 二班       | 小剛,小明,小紅       | +------------+----------------------+

 去重:可以使用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 ;   


+------------+----------------------+ | class_name | std_names            | +------------+----------------------+ | 一班       | 小強(qiáng)                 | | 三班       | 小白,小魚            | | 二班       | 小剛,小明,小紅       | +------------+----------------------+

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

select group_concat(CONCAT_WS('的',class_name,std_name) SEPARATOR ';')  As std_names from test_classes ;    SEPARATOR 是指定分隔符  ```sql +---------------------------------------------------------------------------------------------------------------------------------+ | std_names                                                                                                                       | +---------------------------------------------------------------------------------------------------------------------------------+ | 二班的小明;二班的小紅;二班的小剛;一班的小強(qiáng);三班的小白;三班的小魚;二班的小明;二班的小明                                         | +---------------------------------------------------------------------------------------------------------------------------------+

 長(zhǎng)度限制

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

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

show variables like "group_concat_max_len";

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

SET GLOBAL group_concat_max_len=102400; SET SESSION group_concat_max_len=102400;

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

[mysqld] group_concat_max_len=102400

關(guān)于MySQL中怎么使用group_concat合并列就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI