• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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)

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

    您可能感兴趣的文章:
    • mysql查询的时候给字段赋默认值操作
    • MySQL命令行中给表添加一个字段(字段名、是否为空、默认值)
    • MySQL表字段设置默认值(图文教程及注意细节)
    • MySQL 8.0新特性之隐藏字段的深入讲解
    • 浅谈Mysql哪些字段适合建立索引
    • mysql update case 更新字段值不固定的操作
    • mysql修改记录时update操作 字段=字段+字符串
    • mysql单字段多值分割和合并的处理方法
    • 关于Mysql update修改多个字段and的语法问题详析
    • MySQL 字段默认值该如何设置
    上一篇:MySQL存储过程的查询命令介绍
    下一篇:MySQL实现字符串的拼接,截取,替换,查找位置的操作
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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