五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動(dòng)態(tài)

mysql 多個(gè)字段拼接的實(shí)例詳解

發(fā)布日期:2022-02-19 12:42 | 文章來(lái)源:源碼之家

Mysql的查詢結(jié)果行字段拼接,可以用下面兩個(gè)函數(shù)實(shí)現(xiàn):

1. concat函數(shù)

mysql> select concat('1','2','3') from test ;
+---------------------+
| concat('1','2','3') |
+---------------------+
| 123 |
+---------------------+

如果連接串中存在NULL,則返回結(jié)果為NULL:

mysql> select concat('1','2',NULL,'3') from test ;
+--------------------------+
| concat('1','2',NULL,'3') |
+--------------------------+
| NULL |
+--------------------------+

2. concat_ws函數(shù)

concat(separator,str1,str2,...) 代表 concat with separator ,是concat()的特殊形式。第一個(gè)參數(shù)是其它參數(shù)的分隔符。分隔符的位置放在要連接的兩個(gè)字符串之間。分隔符可以是一個(gè)字符串,也可以是其它參數(shù)。

mysql> select concat_ws(':','1','2','3') from test ;
+----------------------------+
| concat_ws(':','1','2','3') |
+----------------------------+
| 1:2:3 |
+----------------------------+

分隔符為NULL,則返回結(jié)果為NULL:

mysql> select concat_ws(NULL,'1','2','3') from test; 
+-----------------------------+
| concat_ws(NULL,'1','2','3') |
+-----------------------------+
| NULL | 
+-----------------------------+

如果參數(shù)中存在NULL,則會(huì)被忽略:

mysql> select concat_ws(':','1','2',NULL,NULL,NULL,'3') from test ;
+-------------------------------------------+
| concat_ws(':','1','2',NULL,NULL,NULL,'3') |
+-------------------------------------------+
| 1:2:3 |
+-------------------------------------------+

可以對(duì)NULL進(jìn)行判斷,并用其它值進(jìn)行替換:

mysql> select concat_ws(':','1','2',ifNULL(NULL,'0'),'3') from bank limit 1; 
+---------------------------------------------+
| concat_ws(':','1','2',ifNULL(NULL,'0'),'3') |
+---------------------------------------------+
| 1:2:0:3          | 
+---------------------------------------------+

補(bǔ)充:補(bǔ)充:mysql中分組時(shí)將某個(gè)字段的值進(jìn)行拼接

t_dog表

t_vaccine表

t_dog_vaccine表

問(wèn)題描述

我需要將dog_vaccine中每個(gè)狗相對(duì)應(yīng)的疫苗查詢出來(lái),由于狗和疫苗是多對(duì)多的關(guān)系,一個(gè)狗可能對(duì)應(yīng)多個(gè)疫苗,但我想把這多個(gè)疫苗用字符串拼接成一個(gè),然后去映射到j(luò)ava實(shí)體類上。

一步步解決

我用了倆個(gè)左連接查詢使得 t_dog表,t_vaccine表,t_dog_vaccine表這三個(gè)表關(guān)聯(lián)了起來(lái)

select dv.id as id,
 d.dog_name as dogName,v.vaccine_name 
 from 
 t_dog_vaccine dv
  left join t_dog d on dv.dog_id = d.id
  left join t_vaccine v on dv.vaccine_id = v.id 

這樣雖然把狗和疫苗都對(duì)應(yīng)上了,但是每條狗有多條記錄,而我只想要一個(gè)狗的名字和把多個(gè)vaccine_name的值合并成一個(gè)字符串這樣的數(shù)據(jù)。在經(jīng)過(guò)思考以后,我突然想到了·group by 。

select dv.id as id,
 d.dog_name as dogName,v.vaccine_name 
 from 
 t_dog_vaccine dv
  left join t_dog d on dv.dog_id = d.id
  left join t_vaccine v on dv.vaccine_id = v.id 
  group by dogName

用了group by 這明顯不是我想到的結(jié)果啊,dogName雖然只有一個(gè)了,但是它對(duì)應(yīng)的疫苗也只有一個(gè)了,我想要多個(gè)疫苗名,那怎么辦呢? 是不是有個(gè)函數(shù)可以做字符串拼接呢? emmmmm,有了,group_concat。。。

select dv.id as id,
 d.dog_name as dogName,
 group_concat(v.vaccine_name) as dogVaccineName  
 from 
 t_dog_vaccine dv
  left join t_dog d on dv.dog_id = d.id
  left join t_vaccine v on dv.vaccine_id = v.id 
 group by d.dog_name

這下就達(dá)到我想的效果啦。

group_concat用法

默認(rèn)用法

select group_concat(vaccine_name) as dogVaccineName from t_vaccine where id in(select vaccine_id from t_dog_vaccine where dog_id = 1)

group_concat拼接時(shí)默認(rèn)的分隔符是',' ,如果我們想改變這個(gè)分隔符可以這樣做。

REPLACE(group_concat(vaccine_name),',','這里填寫(xiě)你所想換的分隔符')

比如我想把默認(rèn)的,換成;

select REPLACE(group_concat(vaccine_name),',',';') as dogVaccineName from t_vaccine where id in(select vaccine_id from t_dog_vaccine where dog_id = 1)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持本站。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

香港快速服務(wù)器

版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時(shí)開(kāi)通

自選配置、實(shí)時(shí)開(kāi)通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問(wèn)服務(wù)

1對(duì)1客戶咨詢顧問(wèn)

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部