当前位置:数据库 > > 正文

mysql 查询出来的字段拼接(mysql 多个字段拼接的实例详解)

时间:2021-10-21 08:25:53类别:数据库

mysql 查询出来的字段拼接

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

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表

    mysql 查询出来的字段拼接(mysql 多个字段拼接的实例详解)

    t_vaccine表

    mysql 查询出来的字段拼接(mysql 多个字段拼接的实例详解)

    t_dog_vaccine表

    mysql 查询出来的字段拼接(mysql 多个字段拼接的实例详解)

    问题描述

    我需要将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
  • mysql 查询出来的字段拼接(mysql 多个字段拼接的实例详解)

    这样虽然把狗和疫苗都对应上了,但是每条狗有多条记录,而我只想要一个狗的名字和把多个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
  • mysql 查询出来的字段拼接(mysql 多个字段拼接的实例详解)

    用了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
  • mysql 查询出来的字段拼接(mysql 多个字段拼接的实例详解)

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

    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

    标签:
    上一篇下一篇

    猜您喜欢

    热门推荐