mysql字符串拼接的4種方式總結(jié)
目錄
- 前言
- 第一種:
- 第二種:
- 第三種:
- 第四種(運(yùn)算,只對(duì)數(shù)字有效):
- 附:MySQL group_concat()詳解
- 總結(jié)
前言
總是記不住字符串拼接,每次都要百度去搜索,所以在這里記錄一下,好方便后續(xù)的查找,如有錯(cuò)誤和問(wèn)題可以提出,謝謝。
字符串拼接分為幾種方式,在這里會(huì)一一舉例寫(xiě)出:
第一種:
mysql自帶語(yǔ)法CONCAT(string1,string2,…),此處是直接把string1和string2等等的字符串拼接起來(lái)(無(wú)縫拼接哦)
說(shuō)明:此方法在拼接的時(shí)候如果有一個(gè)值為NULL,則返回NULL
如:
1.SELECT CONCAT(“name=”,“lich”,NULL) AS test;
2.SELECT CONCAT(“name=”,“lich”) AS test;
第二種:
第二種也是mysql自帶語(yǔ)法CONCAT_WS(separator,string1,string2,…),但是可以多個(gè)字符串用指定的字符串進(jìn)行拼接(帶縫拼接哦)
說(shuō)明:string1,string2代表的是字符串,而separator代表的是連接其他參數(shù)的分隔符,可以是符號(hào),也可以是字符串。如果分隔符為NULL,則結(jié)果為NULL。此方法參數(shù)可以為NULL。
如:
1.select concat_ws(‘#’,‘name=’,‘lich’,null) AS test;
2.select concat_ws(NULL,‘name=’,‘lich’,null) AS test;
3.select concat_ws(“hello,”,‘name=’,‘lich’,null) AS test;
第三種:
也是mysql的自帶語(yǔ)法GROUP_CONCAT([DISTINCT] 要連接的字段 [Order BY ASC/DESC 排序字段] [Separator ‘分隔符’])
如:
1.SELECT id,GROUP_CONCAT(type) FROM log_sys_interview GROUP BY type ;
2.SELECT id,GROUP_CONCAT(type Separator ‘#’) FROM log_sys_interview GROUP BY type ;
3.SELECT id,GROUP_CONCAT(type ORDER BY type DESC) FROM log_sys_interview GROUP BY ip ;
4.SELECT id,GROUP_CONCAT(DISTINCT type ORDER BY type DESC) FROM log_sys_interview GROUP BY ip ;
第四種(運(yùn)算,只對(duì)數(shù)字有效):
這種方式比較簡(jiǎn)單
原始的:
SELECT id,type FROM log_sys_interview ;
SELECT id,type+99 FROM log_sys_interview ;
附:MySQL group_concat()詳解
GROUP_CONCAT(xxx):是將分組中括號(hào)里對(duì)應(yīng)的字符串進(jìn)行連接.如果分組中括號(hào)里的參數(shù)xxx有多行,那么就會(huì)將這多行的字符串連接,每個(gè)字符串之間會(huì)有特定的符號(hào)進(jìn)行分隔。
對(duì)應(yīng)的語(yǔ)法格式
# 將分組中column1這一列對(duì)應(yīng)的多行的值按照column2 升序或者降序進(jìn)行連接,其中分隔符為seq# 如果用到了DISTINCT,將表示將不重復(fù)的column1按照column2升序或者降序連接# 如果沒(méi)有指定SEPARATOR的話,也就是說(shuō)沒(méi)有寫(xiě),那么就會(huì)默認(rèn)以 ","分隔GROUP_CONCAT([DISTINCT] column1 [ORDER BY column2 ASC\DESC] [SEPARATOR seq]);
[ ORDER BY column2 ASC\DESC] :表示將會(huì)根據(jù)column2升序或者降序連接.其中column2不一定一定要求是column1,只要保證column2在這個(gè)分組中即可.如果沒(méi)有寫(xiě)ORDER BY句段,那么連接是沒(méi)有順序的。
[ SEPARATOR seq] : 表示各個(gè)column1將會(huì)以什么分隔符進(jìn)行分隔,例如SEPARATOR '’,則表示column1將會(huì)以進(jìn)行分隔。如果沒(méi)有指定seq的時(shí)候,也即沒(méi)有寫(xiě)SEPARATOR seq這個(gè)句段,那么就會(huì)默認(rèn)是以,分隔的。
CONCAT函數(shù)中要連接的數(shù)據(jù)含有NULL,最后返回的是NULL,但是GROUP_CONCAT不會(huì)這樣,他會(huì)忽略NULL值。
mysql> SELECT * FROM employee2; +----+-----------+------+---------+---------+ | id | name | age | salary | dept_id | +----+-----------+------+---------+---------+ | 3 | 小肖 | 29 | 30000.0 | 1 | | 4 | 小東 | 30 | 40000.0 | 2 | | 6 | 小非 | 24 | 23456.0 | 3 | | 7 | 曉飛 | 30 | 15000.0 | 4 | | 8 | 小林 | 23 | 24000.0 | NULL | | 10 | 小五 | 20 | 4500.0 | NULL | | 11 | 張山 | 24 | 40000.0 | 1 | | 12 | 小肖 | 28 | 35000.0 | 2 | | 13 | 李四 | 23 | 50000.0 | 1 | | 17 | 王武 | 24 | 56000.0 | 2 | | 18 | 豬小屁 | 2 | 56000.0 | 2 | | 19 | 小玉 | 25 | 58000.0 | 1 | | 21 | 小張 | 23 | 50000.0 | 1 | | 22 | 小胡 | 25 | 25000.0 | 2 | | 96 | 小肖 | 19 | 35000.0 | 1 | | 97 | 小林 | 20 | 20000.0 | 2 | +----+-----------+------+---------+---------+ 16 rows in set (0.16 sec) mysql> SELECT -> dept_id, -> GROUP_CONCAT(name ORDER BY age DESC SEPARATOR "*") -- 分組中的name中的多行數(shù)據(jù)將按照age降序進(jìn)行連接,分隔符為 * -> FROM employee2 -> GROUP BY dept_id; -- 注意如果這里沒(méi)有GROUP BY dept_id,那么就會(huì)因?yàn)檩敵鰀ept_id而發(fā)生報(bào)錯(cuò) +---------+----------------------------------------------------+ | dept_id | GROUP_CONCAT(name ORDER BY age DESC SEPARATOR "*") | +---------+----------------------------------------------------+ | NULL | 小林*小五 | | 1 | 小肖*小玉*張山*小張*李四*小肖 | | 2 | 小東*小肖*小胡*王武*小林*豬小屁 | | 3 | 小非| | 4 | 曉飛| +---------+----------------------------------------------------+ mysql> SELECT -> GROUP_CONCAT(name SEPARATOR "*") -> FROM employee2; -- 這時(shí)候雖然沒(méi)有使用GROUP BY,但是可以正常運(yùn)行,此時(shí)是將所有的name連接,連接時(shí)為無(wú)序,分隔符為* +-------------------------------------------------------------------------------------------------------+ | GROUP_CONCAT(name SEPARATOR "*") | +-------------------------------------------------------------------------------------------------------- | 小肖*小東*小非*曉飛*小林*小五*張山*小肖*李四*王武*豬小屁*小玉*小張*小胡*小肖*小林| +-------------------------------------------------------------------------------------------------------+ 1 row in set (0.00 sec) mysql> SELECT -> GROUP_CONCAT(DISTINCT name SEPARATOR "*") -- 將不同的name進(jìn)行連接 -> FROM employee2; +-----------------------------------------------------------------------------------------------+ | GROUP_CONCAT(DISTINCT name SEPARATOR "*") | +-----------------------------------------------------------------------------------------------+ | 小東*小五*小張*小林*小玉*小肖*小胡*小非*張山*曉飛*李四*豬小屁*王武 | +-----------------------------------------------------------------------------------------------+ 1 row in set (0.00 sec) mysql> SELECT -> dept_id, -> GROUP_CONCAT(name) AS employees -> FROM employee2 -> GROUP BY dept_id; -- 輸出每個(gè)部門(mén)的員工,每個(gè)員工之間用逗號(hào)分隔,因?yàn)闆](méi)有寫(xiě)SEPARATOR ,所以就默認(rèn)以逗號(hào)分隔 +---------+----------------------------------------------+ | dept_id | employees | +---------+----------------------------------------------+ | NULL | 小林,小五 | | 1 | 小肖,張山,李四,小玉,小張,小肖| | 2 | 小東,小肖,王武,豬小屁,小胡,小林 | | 3 | 小非 | | 4 | 曉飛 | +---------+----------------------------------------------+ 5 rows in set (0.00 sec) mysql> SELECT -> dept_id, -> GROUP_CONCAT(DISTINCT name) -- 將不同的name連接,并且用逗號(hào)分隔 -> AS employees -> FROM employee2 -> GROUP BY dept_id; +---------+----------------------------------------------+ | dept_id | employees | +---------+----------------------------------------------+ | NULL | 小五,小林 | | 1 | 小張,小玉,小肖,張山,李四 | | 2 | 小東,小林,小肖,小胡,豬小屁,王武 | | 3 | 小非 | | 4 | 曉飛 | +---------+----------------------------------------------+ 5 rows in set (0.00 sec)
總結(jié)
到此這篇關(guān)于mysql字符串拼接的4種方式的文章就介紹到這了,更多相關(guān)mysql字符串拼接內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!
相關(guān)文章:
