服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - mysql字符串拼接的4种方式总结

mysql字符串拼接的4种方式总结

2023-02-16 12:19奇怪的大象 Mysql

MySQL字符串拼接可以使多个字段的值组成一个集合,不仅可以拼接字符串与字符串、空格、特殊符号甚至可以拼接中文文本,下面这篇文章主要给大家介绍了关于mysql字符串拼接的4种方式,需要的朋友可以参考下

前言

总是记不住字符串拼接,每次都要百度去搜索,所以在这里记录一下,好方便后续的查找,如有错误和问题可以提出,谢谢。

字符串拼接分为几种方式,在这里会一一举例写出:

第一种:

mysql自带语法CONCAT(string1,string2,…),此处是直接把string1和string2等等的字符串拼接起来(无缝拼接哦)

说明:此方法在拼接的时候如果有一个值为NULL,则返回NULL

如:

1.SELECT CONCAT(“name=”,“lich”,NULL) AS test;

mysql字符串拼接的4种方式总结

2.SELECT CONCAT(“name=”,“lich”) AS test;

mysql字符串拼接的4种方式总结

第二种:

第二种也是mysql自带语法CONCAT_WS(separator,string1,string2,…),但是可以多个字符串用指定的字符串进行拼接(带缝拼接哦)

说明:string1,string2代表的是字符串,而separator代表的是连接其他参数的分隔符,可以是符号,也可以是字符串。如果分隔符为NULL,则结果为NULL。此方法参数可以为NULL。

如:

1.select concat_ws(‘#’,‘name=’,‘lich’,null) AS test;

mysql字符串拼接的4种方式总结

2.select concat_ws(NULL,‘name=’,‘lich’,null) AS test;

mysql字符串拼接的4种方式总结

3.select concat_ws(“hello,”,‘name=’,‘lich’,null) AS test;

mysql字符串拼接的4种方式总结

第三种:

也是mysql的自带语法GROUP_CONCAT([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator ‘分隔符’])

如:

1.SELECT id,GROUP_CONCAT(type) FROM log_sys_interview GROUP BY type ;

mysql字符串拼接的4种方式总结

2.SELECT id,GROUP_CONCAT(type Separator ‘#’) FROM log_sys_interview GROUP BY type ;

mysql字符串拼接的4种方式总结

3.SELECT id,GROUP_CONCAT(type ORDER BY type DESC) FROM log_sys_interview GROUP BY ip ;

mysql字符串拼接的4种方式总结

4.SELECT id,GROUP_CONCAT(DISTINCT type ORDER BY type DESC) FROM log_sys_interview GROUP BY ip ;

mysql字符串拼接的4种方式总结

第四种(运算,只对数字有效):

这种方式比较简单

原始的:

SELECT id,type FROM log_sys_interview ;

mysql字符串拼接的4种方式总结

SELECT id,type+99 FROM log_sys_interview ;

mysql字符串拼接的4种方式总结

附:MySQL group_concat()详解

GROUP_CONCAT(xxx):是将分组中括号里对应的字符串进行连接.如果分组中括号里的参数xxx有多行,那么就会将这多行的字符串连接,每个字符串之间会有特定的符号进行分隔。

对应的语法格式

# 将分组中column1这一列对应的多行的值按照column2 升序或者降序进行连接,其中分隔符为seq
# 如果用到了DISTINCT,将表示将不重复的column1按照column2升序或者降序连接
# 如果没有指定SEPARATOR的话,也就是说没有写,那么就会默认以 ','分隔
GROUP_CONCAT([DISTINCT] column1 [ORDER BY column2 ASC\DESC] [SEPARATOR seq]);

[ ORDER BY column2 ASC\DESC] :表示将会根据column2升序或者降序连接.其中column2不一定一定要求是column1,只要保证column2在这个分组中即可.如果没有写ORDER BY句段,那么连接是没有顺序的。

[ SEPARATOR seq] : 表示各个column1将会以什么分隔符进行分隔,例如SEPARATOR '’,则表示column1将会以进行分隔。如果没有指定seq的时候,也即没有写SEPARATOR seq这个句段,那么就会默认是以,分隔的。

CONCAT函数中要连接的数据含有NULL,最后返回的是NULL,但是GROUP_CONCAT不会这样,他会忽略NULL值。

    mysql> SELECT * FROM employee2;
      +----+-----------+------+---------+---------+
      | id | name      | age  | salary  | dept_id |
      +----+-----------+------+---------+---------+
      |  3 | 小肖      |   29 | 30000.0 |       1 |
      |  4 | 小东      |   30 | 40000.0 |       2 |
      |  6 | 小非      |   24 | 23456.0 |       3 |
      |  7 | 晓飞      |   30 | 15000.0 |       4 |
      |  8 | 小林      |   23 | 24000.0 |    NULL |
      | 10 | 小五      |   20 |  4500.0 |    NULL |
      | 11 | 张山      |   24 | 40000.0 |       1 |
      | 12 | 小肖      |   28 | 35000.0 |       2 |
      | 13 | 李四      |   23 | 50000.0 |       1 |
      | 17 | 王武      |   24 | 56000.0 |       2 |
      | 18 | 猪小屁    |    2 | 56000.0 |       2 |
      | 19 | 小玉      |   25 | 58000.0 |       1 |
      | 21 | 小张      |   23 | 50000.0 |       1 |
      | 22 | 小胡      |   25 | 25000.0 |       2 |
      | 96 | 小肖      |   19 | 35000.0 |       1 |
      | 97 | 小林      |   20 | 20000.0 |       2 |
      +----+-----------+------+---------+---------+
      16 rows in set (0.16 sec)
      
      mysql> SELECT
          -> dept_id,
          -> GROUP_CONCAT(name ORDER BY age DESC SEPARATOR '*') -- 分组中的name中的多行数据将按照age降序进行连接,分隔符为 * 
          -> FROM employee2
          -> GROUP BY dept_id; -- 注意如果这里没有GROUP BY dept_id,那么就会因为输出dept_id而发生报错
      +---------+----------------------------------------------------+
      | dept_id | GROUP_CONCAT(name ORDER BY age DESC SEPARATOR '*') |
      +---------+----------------------------------------------------+
      |    NULL | 小林*小五                                           |
      |       1 | 小肖*小玉*张山*小张*李四*小肖                          |
      |       2 | 小东*小肖*小胡*王武*小林*猪小屁                         |
      |       3 | 小非                                                |
      |       4 | 晓飞                                                |
      +---------+----------------------------------------------------+
      
      
      mysql> SELECT
          -> GROUP_CONCAT(name SEPARATOR '*') 
          -> FROM employee2; -- 这时候虽然没有使用GROUP BY,但是可以正常运行,此时是将所有的name连接,连接时为无序,分隔符为*
      +-------------------------------------------------------------------------------------------------------+
      | GROUP_CONCAT(name SEPARATOR '*')                                                                      | 
      +--------------------------------------------------------------------------------------------------------
      | 小肖*小东*小非*晓飞*小林*小五*张山*小肖*李四*王武*猪小屁*小玉*小张*小胡*小肖*小林                                | 
      +-------------------------------------------------------------------------------------------------------+
      1 row in set (0.00 sec)
      
      mysql> SELECT
          -> GROUP_CONCAT(DISTINCT name SEPARATOR '*') -- 将不同的name进行连接
          -> FROM employee2;
      +-----------------------------------------------------------------------------------------------+
      | GROUP_CONCAT(DISTINCT name SEPARATOR '*')                                                     |
      +-----------------------------------------------------------------------------------------------+
      | 小东*小五*小张*小林*小玉*小肖*小胡*小非*张山*晓飞*李四*猪小屁*王武                            |
      +-----------------------------------------------------------------------------------------------+
      1 row in set (0.00 sec)
      
      
      mysql> SELECT
          -> dept_id,
          -> GROUP_CONCAT(name) AS employees
          -> FROM employee2
          -> GROUP BY dept_id; -- 输出每个部门的员工,每个员工之间用逗号分隔,因为没有写SEPARATOR ,所以就默认以逗号分隔
      +---------+----------------------------------------------+
      | dept_id | employees                                    |
      +---------+----------------------------------------------+
      |    NULL | 小林,小五                                    |
      |       1 | 小肖,张山,李四,小玉,小张,小肖                |
      |       2 | 小东,小肖,王武,猪小屁,小胡,小林              |
      |       3 | 小非                                         |
      |       4 | 晓飞                                         |
      +---------+----------------------------------------------+
      5 rows in set (0.00 sec)
      
      mysql> SELECT
          -> dept_id,
          -> GROUP_CONCAT(DISTINCT name) -- 将不同的name连接,并且用逗号分隔
          -> AS employees
          -> FROM  employee2
          -> GROUP BY dept_id;
      +---------+----------------------------------------------+
      | dept_id | employees                                    |
      +---------+----------------------------------------------+
      |    NULL | 小五,小林                                    |
      |       1 | 小张,小玉,小肖,张山,李四                     |
      |       2 | 小东,小林,小肖,小胡,猪小屁,王武              |
      |       3 | 小非                                         |
      |       4 | 晓飞                                         |
      +---------+----------------------------------------------+
      5 rows in set (0.00 sec)

总结 

到此这篇关于mysql字符串拼接的4种方式的文章就介绍到这了,更多相关mysql字符串拼接内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/m0_67391120/article/details/126469952

延伸 · 阅读

精彩推荐
  • MysqlUbuntu20下MySQL 8.0.28 安装卸载方法图文教程

    Ubuntu20下MySQL 8.0.28 安装卸载方法图文教程

    这篇文章主要为大家详细介绍了Ubuntu20下MySQL 8.0.28 安装卸载方法图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参...

    理默桐10962022-10-21
  • MysqlMySQL5.6升级5.7时出现主从延迟问题排查过程

    MySQL5.6升级5.7时出现主从延迟问题排查过程

    这篇文章主要介绍了MySQL5.6升级5.7时出现主从延迟问题排查过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需...

    AIOPS_DBA8812021-02-02
  • MysqlMySQL连接控制插件介绍

    MySQL连接控制插件介绍

    当连接数据库失败次数过多时,MySQL 是否会限制登录呢?数据库服务端应该怎么应对暴力破解呢?本篇文章介绍下 MySQL 中的连接控制插件,一起来学习下此...

    MySQL技术7662021-11-17
  • Mysql在MySQL中使用STRAIGHT_JOIN的教程

    在MySQL中使用STRAIGHT_JOIN的教程

    这篇文章主要介绍了在MySQL中使用STRAIGHT_JOIN的教程,包括使用STRAIGHT_JOIN进行一些性能上的优化的技巧,需要的朋友可以参考下 ...

    MYSQL教程网5622020-05-11
  • Mysqlmysql DBA:mysqladmin常用命令总结

    mysql DBA:mysqladmin常用命令总结

    mysqladmin是MySQL一个重要的客户端,最常见的是使用它来关闭数据库,除此,该命令还可以了解MySQL运行状态、进程信息、进程杀死等。本文介绍一下如何使...

    MYSQL教程网4942020-03-20
  • MysqlRR与RC隔离级别下索引和锁的测试脚本示例代码

    RR与RC隔离级别下索引和锁的测试脚本示例代码

    这篇文章主要给大家介绍了关于RR与RC隔离级别下索引和锁的测试脚本的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参...

    stuartlau5302019-06-14
  • Mysql设置MySQL自动增长从某个指定的数开始方法

    设置MySQL自动增长从某个指定的数开始方法

    下面小编就为大家带来一篇设置MySQL自动增长从某个指定的数开始方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看...

    mysql教程网3732020-07-08
  • MysqlMySQL GTID全面总结

    MySQL GTID全面总结

    这篇文章主要介绍了MySQL GTID的相关资料,帮助大家更好的理解和学习使用MySQL数据库,感兴趣的朋友可以了解下...

    AsiaYe5162021-04-30