這篇文章給大家介紹MySQL中怎么使用group_concat合并列,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
成都創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站建設(shè)、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的富蘊(yùn)網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
創(chuàng)建一個測試表進(jìn)行測試
create table test_classes (std_name varchar(200),class_name varchar(200)); insert into test_classes (std_name , class_name ) value ("小明","二班") , ("小紅","二班") ,("小剛","二班"), ("小強(qiáng)","一班"), ("小白","三班") ,("小魚","三班");
需求:查出三個班級各有什么人,并使用一個字符串的字段顯示。
這時候直接使用group_concat一個語句就可以直接完成。
select class_name , group_concat(std_name) As std_names from test_classes group by class_name ;
這里需要根據(jù)班級來顯示,所以需要使用group_by進(jìn)行分組
+------------+----------------------+ | class_name | std_names | +------------+----------------------+ | 一班 | 小強(qiáng) | | 三班 | 小白,小魚 | | 二班 | 小明,小紅,小剛 | +------------+----------------------+
排序:在group_concat也是支持排序的。
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)行去重。
insert into test_classes (std_name , class_name ) value ("小明","二班");
insert into test_classes (std_name , class_name ) value ("小明","二班");
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將多列合并成一個字符串。
select group_concat(CONCAT_WS('的',class_name,std_name) SEPARATOR ';') As std_names from test_classes ; SEPARATOR 是指定分隔符 ```sql +---------------------------------------------------------------------------------------------------------------------------------+ | std_names | +---------------------------------------------------------------------------------------------------------------------------------+ | 二班的小明;二班的小紅;二班的小剛;一班的小強(qiáng);三班的小白;三班的小魚;二班的小明;二班的小明 | +---------------------------------------------------------------------------------------------------------------------------------+
GROUP_CONCAT這個函數(shù)是有最大長度限制的,如果超過這個長度限制,得到的字符串就是被截取后的結(jié)果,不會報錯,所以需要注意。
這個是長度是由變量group_concat_max_len控制的。
show variables like "group_concat_max_len";
可以通過修改這個變量來放大限制。
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)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。