mysql 多个字段拼接的实例详解
Mysql的查询结果行字段拼接,可以用下面两个函数实现:
1.concat函数
mysql>selectconcat('1','2','3')fromtest; +---------------------+ |concat('1','2','3')| +---------------------+ |123| +---------------------+
如果连接串中存在NULL,则返回结果为NULL:
mysql>selectconcat('1','2',NULL,'3')fromtest; +--------------------------+ |concat('1','2',NULL,'3')| +--------------------------+ |NULL| +--------------------------+
2.concat_ws函数
concat(separator,str1,str2,...)代表concatwithseparator,是concat()的特殊形式。第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。
mysql>selectconcat_ws(':','1','2','3')fromtest; +----------------------------+ |concat_ws(':','1','2','3')| +----------------------------+ |1:2:3| +----------------------------+
分隔符为NULL,则返回结果为NULL:
mysql>selectconcat_ws(NULL,'1','2','3')fromtest; +-----------------------------+ |concat_ws(NULL,'1','2','3')| +-----------------------------+ |NULL| +-----------------------------+
如果参数中存在NULL,则会被忽略:
mysql>selectconcat_ws(':','1','2',NULL,NULL,NULL,'3')fromtest; +-------------------------------------------+ |concat_ws(':','1','2',NULL,NULL,NULL,'3')| +-------------------------------------------+ |1:2:3| +-------------------------------------------+
可以对NULL进行判断,并用其它值进行替换:
mysql>selectconcat_ws(':','1','2',ifNULL(NULL,'0'),'3')frombanklimit1; +---------------------------------------------+ |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表这三个表关联了起来
selectdv.idasid, d.dog_nameasdogName,v.vaccine_name from t_dog_vaccinedv leftjoint_dogdondv.dog_id=d.id leftjoint_vaccinevondv.vaccine_id=v.id
这样虽然把狗和疫苗都对应上了,但是每条狗有多条记录,而我只想要一个狗的名字和把多个vaccine_name的值合并成一个字符串这样的数据。在经过思考以后,我突然想到了·groupby。
selectdv.idasid, d.dog_nameasdogName,v.vaccine_name from t_dog_vaccinedv leftjoint_dogdondv.dog_id=d.id leftjoint_vaccinevondv.vaccine_id=v.id groupbydogName
用了groupby这明显不是我想到的结果啊,dogName虽然只有一个了,但是它对应的疫苗也只有一个了,我想要多个疫苗名,那怎么办呢?是不是有个函数可以做字符串拼接呢?emmmmm,有了,group_concat。。。
selectdv.idasid, d.dog_nameasdogName, group_concat(v.vaccine_name)asdogVaccineName from t_dog_vaccinedv leftjoint_dogdondv.dog_id=d.id leftjoint_vaccinevondv.vaccine_id=v.id groupbyd.dog_name
这下就达到我想的效果啦。
group_concat用法
默认用法
selectgroup_concat(vaccine_name)asdogVaccineNamefromt_vaccinewhereidin(selectvaccine_idfromt_dog_vaccinewheredog_id=1)
group_concat拼接时默认的分隔符是',',如果我们想改变这个分隔符可以这样做。
REPLACE(group_concat(vaccine_name),',','这里填写你所想换的分隔符')
比如我想把默认的,换成;
selectREPLACE(group_concat(vaccine_name),',',';')asdogVaccineNamefromt_vaccinewhereidin(selectvaccine_idfromt_dog_vaccinewheredog_id=1)
以上为个人经验,希望能给大家一个参考,也希望大家多多支持毛票票。如有错误或未考虑完全的地方,望不吝赐教。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。