mysql 多个字段拼接的实例详解
Mysql的查询结果行字段拼接,可以用狼蚁网站SEO优化两个函数实现
1. concat函数
mysql> select concat('1','2','3') from test ; +---------------------+ | concat('1','2','3') | +---------------------+ | 123 | +---------------------+
如果连接串中存在NULL,则返回结果为NULL
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()的特殊形式。第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。
mysql> select concat_ws(':','1','2','3') from test ; +----------------------------+ | concat_ws(':','1','2','3') | +----------------------------+ | 1:2:3 | +----------------------------+
分隔符为NULL,则返回结果为NULL
mysql> select concat_ws(NULL,'1','2','3') from test; +-----------------------------+ | concat_ws(NULL,'1','2','3') | +-----------------------------+ | NULL | +-----------------------------+
如果参数中存在NULL,则会被忽略
mysql> select concat_ws(':','1','2',NULL,NULL,NULL,'3') from test ; +-------------------------------------------+ | concat_ws(':','1','2',NULL,NULL,NULL,'3') | +-------------------------------------------+ | 1:2:3 | +-------------------------------------------+
可以对NULL进行判断,并用其它值进行替换
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_vaine表
t_dog_vaine表
问题描述
我需要将dog_vaine中每个狗相对应的疫苗查询出来,由于狗和疫苗是多对多的关系,一个狗可能对应多个疫苗,但我想把这多个疫苗用字符串拼接成一个,然后去映射到java实体类上。
一步步解决
我用了俩个左连接查询使得 t_dog表,t_vaine表,t_dog_vaine表这三个表关联了起来
select dv.id as id, d.dog_name as dogName,v.vaine_name from t_dog_vaine dv left join t_dog d on dv.dog_id = d.id left join t_vaine v on dv.vaine_id = v.id
这样虽然把狗和疫苗都对应上了,每条狗有多条记录,而我只想要一个狗的名字和把多个vaine_name的值合并成一个字符串这样的数据。在经过思考以后,我突然想到了·group by 。
select dv.id as id, d.dog_name as dogName,v.vaine_name from t_dog_vaine dv left join t_dog d on dv.dog_id = d.id left join t_vaine v on dv.vaine_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.vaine_name) as dogVaineName from t_dog_vaine dv left join t_dog d on dv.dog_id = d.id left join t_vaine v on dv.vaine_id = v.id group by d.dog_name
这下就达到我想的效果啦。
group_concat用法
默认用法
select group_concat(vaine_name) as dogVaineName from t_vaine where id in(select vaine_id from t_dog_vaine where dog_id = 1)
group_concat拼接时默认的分隔符是',' ,如果我们想改变这个分隔符可以这样做。
REPLACE(group_concat(vaine_name),',','这里填写你所想换的分隔符')
比如我想把默认的,换成;
select REPLACE(group_concat(vaine_name),',',';') as dogVaineName from t_vaine where id in(select vaine_id from t_dog_vaine where dog_id = 1)
以上为个人经验,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。如有错误或未考虑完全的地方,望不吝赐教。
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南