各位用户为了找寻关于mysql 多个字段拼接的实例详解的资料费劲了很多周折。这里教程网为您整理了关于mysql 多个字段拼接的实例详解的相关资料,仅供查阅,以下为您介绍关于mysql 多个字段拼接的实例详解的详细内容
mysql的查询结果行字段拼接,可以用下面两个函数实现:
1. concat函数
? 1 2 3 4 5 6mysql>
select
concat(
'1'
,
'2'
,
'3'
)
from
test ;
+
---------------------+
| concat(
'1'
,
'2'
,
'3'
) |
+
---------------------+
| 123 |
+
---------------------+
如果连接串中存在null,则返回结果为null:
? 1 2 3 4 5 6mysql>
select
concat(
'1'
,
'2'
,
null
,
'3'
)
from
test ;
+
--------------------------+
| concat(
'1'
,
'2'
,
null
,
'3'
) |
+
--------------------------+
|
null
|
+
--------------------------+
2. concat_ws函数
concat(separator,str1,str2,...) 代表 concat with separator ,是concat()的特殊形式。第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。
? 1 2 3 4 5 6mysql>
select
concat_ws(
':'
,
'1'
,
'2'
,
'3'
)
from
test ;
+
----------------------------+
| concat_ws(
':'
,
'1'
,
'2'
,
'3'
) |
+
----------------------------+
| 1:2:3 |
+
----------------------------+
分隔符为null,则返回结果为null:
? 1 2 3 4 5 6mysql>
select
concat_ws(
null
,
'1'
,
'2'
,
'3'
)
from
test;
+
-----------------------------+
| concat_ws(
null
,
'1'
,
'2'
,
'3'
) |
+
-----------------------------+
|
null
|
+
-----------------------------+
如果参数中存在null,则会被忽略:
? 1 2 3 4 5 6mysql>
select
concat_ws(
':'
,
'1'
,
'2'
,
null
,
null
,
null
,
'3'
)
from
test ;
+
-------------------------------------------+
| concat_ws(
':'
,
'1'
,
'2'
,
null
,
null
,
null
,
'3'
) |
+
-------------------------------------------+
| 1:2:3 |
+
-------------------------------------------+
可以对null进行判断,并用其它值进行替换:
? 1 2 3 4 5 6mysql>
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 |
+
---------------------------------------------+
补充:补充:mysql中分组时将某个字段的值进行拼接
t_dog表
t_vaccine表
t_dog_vaccine表
问题描述
我需要将dog_vaccine中每个狗相对应的疫苗查询出来,由于狗和疫苗是多对多的关系,一个狗可能对应多个疫苗,但我想把这多个疫苗用字符串拼接成一个,然后去映射到java实体类上。
一步步解决
我用了俩个左连接查询使得 t_dog表,t_vaccine表,t_dog_vaccine表这三个表关联了起来
? 1 2 3 4 5 6select
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
这样虽然把狗和疫苗都对应上了,但是每条狗有多条记录,而我只想要一个狗的名字和把多个vaccine_name的值合并成一个字符串这样的数据。在经过思考以后,我突然想到了·group by 。
? 1 2 3 4 5 6 7select
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 这明显不是我想到的结果啊,dogname虽然只有一个了,但是它对应的疫苗也只有一个了,我想要多个疫苗名,那怎么办呢? 是不是有个函数可以做字符串拼接呢? emmmmm,有了,group_concat。。。
? 1 2 3 4 5 6 7 8select
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
这下就达到我想的效果啦。
group_concat用法
默认用法
? 1select
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拼接时默认的分隔符是',' ,如果我们想改变这个分隔符可以这样做。
? 1replace
(group_concat(vaccine_name),
','
,
'这里填写你所想换的分隔符'
)
比如我想把默认的,换成;
? 1select
replace
(group_concat(vaccine_name),
','
,
';'
)
as
dogvaccinename
from
t_vaccine
where
id
in
(
select
vaccine_id
from
t_dog_vaccine
where
dog_id = 1)
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/Desilting/article/details/38563087