mysql 多个字段拼接的实例详解

吾爱主题 阅读:131 2024-04-02 08:00:08 评论:0

mysql的查询结果行字段拼接,可以用下面两个函数实现:

1. concat函数

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

如果连接串中存在null,则返回结果为null:

?
1 2 3 4 5 6 mysql> 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 6 mysql> select concat_ws( ':' , '1' , '2' , '3' ) from test ; + ----------------------------+ | concat_ws( ':' , '1' , '2' , '3' ) | + ----------------------------+ | 1:2:3 | + ----------------------------+

分隔符为null,则返回结果为null:

?
1 2 3 4 5 6 mysql> select concat_ws( null , '1' , '2' , '3' ) from test; + -----------------------------+ | concat_ws( null , '1' , '2' , '3' ) | + -----------------------------+ | null | + -----------------------------+

如果参数中存在null,则会被忽略:

?
1 2 3 4 5 6 mysql> 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 6 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          | + ---------------------------------------------+

补充:补充:mysql中分组时将某个字段的值进行拼接

t_dog表

t_vaccine表

t_dog_vaccine表

问题描述

我需要将dog_vaccine中每个狗相对应的疫苗查询出来,由于狗和疫苗是多对多的关系,一个狗可能对应多个疫苗,但我想把这多个疫苗用字符串拼接成一个,然后去映射到java实体类上。

一步步解决

我用了俩个左连接查询使得 t_dog表,t_vaccine表,t_dog_vaccine表这三个表关联了起来

?
1 2 3 4 5 6 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

这样虽然把狗和疫苗都对应上了,但是每条狗有多条记录,而我只想要一个狗的名字和把多个vaccine_name的值合并成一个字符串这样的数据。在经过思考以后,我突然想到了·group by 。

?
1 2 3 4 5 6 7 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 这明显不是我想到的结果啊,dogname虽然只有一个了,但是它对应的疫苗也只有一个了,我想要多个疫苗名,那怎么办呢? 是不是有个函数可以做字符串拼接呢? emmmmm,有了,group_concat。。。

?
1 2 3 4 5 6 7 8 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

这下就达到我想的效果啦。

group_concat用法

默认用法

?
1 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拼接时默认的分隔符是',' ,如果我们想改变这个分隔符可以这样做。

?
1 replace (group_concat(vaccine_name), ',' , '这里填写你所想换的分隔符' )

比如我想把默认的,换成;

?
1 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)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。

原文链接:https://blog.csdn.net/Desilting/article/details/38563087

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容