<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
總是記不住字串拼接,每次都要百度去搜尋,所以在這裡記錄一下,好方便後續的查詢,如有錯誤和問題可以提出,謝謝。
字串拼接分為幾種方式,在這裡會一一舉例寫出:
mysql自帶語法CONCAT(string1,string2,…),此處是直接把string1和string2等等的字串拼接起來(無縫拼接哦)
說明:此方法在拼接的時候如果有一個值為NULL,則返回NULL
如:
1.SELECT CONCAT(“name=”,“lich”,NULL) AS test;
2.SELECT CONCAT(“name=”,“lich”) AS test;
第二種也是mysql自帶語法CONCAT_WS(separator,string1,string2,…),但是可以多個字串用指定的字串進行拼接(帶縫拼接哦)
說明:string1,string2代表的是字串,而separator代表的是連線其他引數的分隔符,可以是符號,也可以是字串。如果分隔符為NULL,則結果為NULL。此方法引數可以為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的自帶語法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 ;
這種方式比較簡單
原始的:
SELECT id,type FROM log_sys_interview ;
SELECT id,type+99 FROM log_sys_interview ;
GROUP_CONCAT(xxx):是將分組中括號裡對應的字串進行連線.如果分組中括號裡的引數xxx有多行,那麼就會將這多行的字串連線,每個字串之間會有特定的符號進行分隔。
對應的語法格式
# 將分組中column1這一列對應的多行的值按照column2 升序或者降序進行連線,其中分隔符為seq # 如果用到了DISTINCT,將表示將不重複的column1按照column2升序或者降序連線 # 如果沒有指定SEPARATOR的話,也就是說沒有寫,那麼就會預設以 ','分隔 GROUP_CONCAT([DISTINCT] column1 [ORDER BY column2 ASCDESC] [SEPARATOR seq]);
[ ORDER BY column2 ASCDESC] :表示將會根據column2升序或者降序連線.其中column2不一定一定要求是column1,只要保證column2在這個分組中即可.如果沒有寫ORDER BY句段,那麼連線是沒有順序的。
[ SEPARATOR seq] : 表示各個column1將會以什麼分隔符進行分隔,例如SEPARATOR '’,則表示column1將會以進行分隔。如果沒有指定seq的時候,也即沒有寫SEPARATOR seq這個句段,那麼就會預設是以,分隔的。
CONCAT函數中要連線的資料含有NULL,最後返回的是NULL,但是GROUP_CONCAT不會這樣,他會忽略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中的多行資料將按照age降序進行連線,分隔符為 * -> FROM employee2 -> GROUP BY dept_id; -- 注意如果這裡沒有GROUP BY dept_id,那麼就會因為輸出dept_id而發生報錯 +---------+----------------------------------------------------+ | dept_id | GROUP_CONCAT(name ORDER BY age DESC SEPARATOR '*') | +---------+----------------------------------------------------+ | NULL | 小林*小五 | | 1 | 小肖*小玉*張山*小張*李四*小肖 | | 2 | 小東*小肖*小胡*王武*小林*豬小屁 | | 3 | 小非 | | 4 | 曉飛 | +---------+----------------------------------------------------+ mysql> SELECT -> GROUP_CONCAT(name SEPARATOR '*') -> FROM employee2; -- 這時候雖然沒有使用GROUP BY,但是可以正常執行,此時是將所有的name連線,連線時為無序,分隔符為* +-------------------------------------------------------------------------------------------------------+ | GROUP_CONCAT(name SEPARATOR '*') | +-------------------------------------------------------------------------------------------------------- | 小肖*小東*小非*曉飛*小林*小五*張山*小肖*李四*王武*豬小屁*小玉*小張*小胡*小肖*小林 | +-------------------------------------------------------------------------------------------------------+ 1 row in set (0.00 sec) mysql> SELECT -> GROUP_CONCAT(DISTINCT name SEPARATOR '*') -- 將不同的name進行連線 -> 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; -- 輸出每個部門的員工,每個員工之間用逗號分隔,因為沒有寫SEPARATOR ,所以就預設以逗號分隔 +---------+----------------------------------------------+ | dept_id | employees | +---------+----------------------------------------------+ | NULL | 小林,小五 | | 1 | 小肖,張山,李四,小玉,小張,小肖 | | 2 | 小東,小肖,王武,豬小屁,小胡,小林 | | 3 | 小非 | | 4 | 曉飛 | +---------+----------------------------------------------+ 5 rows in set (0.00 sec) mysql> SELECT -> dept_id, -> GROUP_CONCAT(DISTINCT name) -- 將不同的name連線,並且用逗號分隔 -> AS employees -> FROM employee2 -> GROUP BY dept_id; +---------+----------------------------------------------+ | dept_id | employees | +---------+----------------------------------------------+ | NULL | 小五,小林 | | 1 | 小張,小玉,小肖,張山,李四 | | 2 | 小東,小林,小肖,小胡,豬小屁,王武 | | 3 | 小非 | | 4 | 曉飛 | +---------+----------------------------------------------+ 5 rows in set (0.00 sec)
到此這篇關於mysql字串拼接的4種方式的文章就介紹到這了,更多相關mysql字串拼接內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45