mysql 查询出来的字段拼接(mysql 多个字段拼接的实例详解)
mysql 查询出来的字段拼接
mysql 多个字段拼接的实例详解mysql的查询结果行字段拼接,可以用下面两个函数实现:
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_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) |
以上为个人经验,希望能给大家一个参考,也希望大家多多支持开心学习网。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/Desilting/article/details/38563087
- mysql怎么设置某个字段默认值(MySQL表字段时间设置默认值)
- mysql中innodb四种事务级别(MySQL InnoDB 锁的相关总结)
- navicat怎么和mysql连接(Navicat Premium远程连接MySQL数据库的方法)
- mysql查询count很慢(MySQL COUNT函数的使用与优化)
- MYSQL字符集设置的方法详解(终端的字符集)(MYSQL字符集设置的方法详解终端的字符集)
- mysql重启启动失败(MySQL8.0无法启动3534的解决方法)
- mysql创建存储过程的代码(MySQL修改存储过程的详细步骤)
- mysql利用数据库日志恢复数据(MySQL通过binlog恢复数据)
- mysql 触发器是什么(MySQL触发器的使用)
- mysql云数据库数据恢复(MySQL 利用frm文件和ibd文件恢复表数据)
- mysql开启事务没有提交(MySQL 事务autocommit自动提交操作)
- mysql拼接和过滤(mysql 如何动态修改复制过滤器)
- mysql3种日志(mysql中的7种日志小结)
- mysqlsource命令作用(MySQL source命令的使用简介)
- mysql错误代码之1064的解决方案(mysql错误代码之1064的解决方案)
- navicat for mysql连接测试失败(Navicat连接虚拟机mysql常见错误问题及解决方法)
- 常见的喜阴植物有哪些 养室内盆栽就在这里选(常见的喜阴植物有哪些)
- 这8种耐阴植物,营造阴生植物花境,也是一个不错的选择(营造阴生植物花境)
- 览邦G08 Plus SMART WATCH 测评⑱ 全独立这才是智能手表该有的样子(览邦G08PlusSMART)
- 荣耀手表 GS 3 真机亮相 不支持无线充电(荣耀手表GS3)
- 通过体温就能为智能手表充电 原来是用NASA在空间站用的黑科技(通过体温就能为智能手表充电)
- 智能手表兼容Windows和Android 无需充电挑战苹果(智能手表兼容Windows和Android)
热门推荐
- css样式为什么要有空格(css几种解决inline-block间隙的方案整理)
- vue重置密码(Vue 两个字段联合校验之修改密码功能的实现)
- ASP.NET中XML和JSON互转
- 阿里云服务器远程连不上(阿里云控制台重置密码重启后无法访问服务器的原因及解决方法)
- mysql数据字段默认值怎么设置(MySQL 字段默认值该如何设置)
- 基于docker的平台搭建(基于docker搭建selenium分布式环境)
- css 页面加载样式(如何只在IE上加载CSS样式表)
- dockerfile启动容器服务(docker文件存放路径, 获取容器启动命令操作)
- dede模板手机端显示设置(DEDE模板中如何运行php脚本和变量在需要操作数据库字段时)
- linux系统显示时间的命令(详解Linux time 命令的使用)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9