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

t_dog表
这里写图片描述
t_vaccine表
这里写图片描述
t_dog_vaccine表
这里写图片描述

问题描述

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

一步步解决

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

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

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。。。

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用法

默认用法

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拼接时默认的分隔符是’,’ ,如果我们想改变这个分隔符可以这样做。
REPLACE(group_concat(vaccine_name),',','这里填写你所想换的分隔符')

比如我想把默认的换成;

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)
  • 16
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值