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

目录
  • 前言
  • 第一种:
  • 第二种:
  • 第三种:
  • 第四种(运算,只对数字有效):
  • 附:MySQL group_concat()详解
  • 总结

前言

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

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

第一种:

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

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

如:

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

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

第二种:

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

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

如:

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

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

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

第三种:

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

如:

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

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

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

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

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

这种方式比较简单

原始的:

SELECT id,type FROM log_sys_interview ;

SELECT id,type+99 FROM log_sys_interview ;

附: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字符串拼接内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • MySQL中字符串与Num类型拼接报错的解决方法

    发现问题 图片地址如下 http://qximg.lightplan.cc/2016/09/11/1473574486942944.jpeg 需要实现的效果是要加上尺寸,如以下效果 http://qximg.lightplan.cc/2016/09/11/1473574486942944.jpeg|1200*675 一开始想当然使用 UPDATE tag_group SET cover = cover + '|1200*675' WHERE id = 1; 结果报错 Data truncatio

  • MySQL实现字段或字符串拼接的三种方式总结

    目录 一.CONCAT函数 1.1.拼接非空字段或字符串 1.2.拼接空(NULL)字段 二.CONCAT_WS函数 2.1.拼接非空字段或字符串 2.2.拼接空(NULL)字段 三.GROUP_CONCAT函数 3.1.默认以逗号分隔符连接 3.2.可自定义对字段去重排序和指定分隔符 3.3.group_concat的限制和设置 一.CONCAT函数 concat函数是将多个字段或字符串拼接为一个字符串:但是字符串之间没有任何分隔. concat函数官方介绍 -- CONCAT函数的语法如下:

  • MySql逗号拼接字符串查询的两种方法

    下面两个函数的使用和FIND_IN_SET一样,使用时只需要把FIND_IN_SET换成FIND_PART_IN_SET或FIND_ALL_PART_IN_SET 例如某字段里是为1,2,3,4,5 使用方法: 第一种,传入1,3,6  可以查出来 select * from XXX where FIND_PART_IN_SET('1,3,6','1,2,3,4,5') 第二种,传入1,3,6  查不出来 select * from XXX where FIND_ALL_PART_IN_SET(

  • MySQL拼接字符串函数GROUP_CONCAT详解

    上一篇文章 跨表更新,看到自己写的SQL像个憨憨写了关于跨表个更新的内容.一年过的很快,文中后来的两位员工 馮大 和 馮二 也要面对无情的 KPI 考核了,他们工作干的很不错,performance 分别是 4 和 5 新需求来了,静悄悄的来了!!! 领导想要查看每个 performance 下都有谁,同时要求将这些人的名称要逗号拼接成一个字符串,也就是说要得到下面的结果: 要将结果集中某个指定的列进行字符串拼接,这要怎么做呢?主角闪亮✨登场 GROUP_CONCAT(expr) 在 Mysql

  • MySQL实现字符串的拼接,截取,替换,查找位置的操作

    MySQL字符串的拼接.截取.替换.查找位置. 常用的字符串函数: 函数 说明 CONCAT(s1,s2,...) 返回连接参数产生的字符串,一个或多个待拼接的内容,任意一个为NULL则返回值为NULL. CONCAT_WS(x,s1,s2,...) 返回多个字符串拼接之后的字符串,每个字符串之间有一个x. SUBSTRING(s,n,len).MID(s,n,len) 两个函数作用相同,从字符串s中返回一个第n个字符开始.长度为len的字符串. LEFT(s,n).RIGHT(s,n) 前者返

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

    目录 前言 第一种: 第二种: 第三种: 第四种(运算,只对数字有效): 附:MySQL group_concat()详解 总结 前言 总是记不住字符串拼接,每次都要百度去搜索,所以在这里记录一下,好方便后续的查找,如有错误和问题可以提出,谢谢. 字符串拼接分为几种方式,在这里会一一举例写出: 第一种: mysql自带语法CONCAT(string1,string2,…),此处是直接把string1和string2等等的字符串拼接起来(无缝拼接哦) 说明:此方法在拼接的时候如果有一个值为NULL

  • Python字符串拼接的几种方法整理

    Python字符串拼接的几种方法整理 第一种 通过加号(+)的形式 print('第一种方式通过加号形式连接 :' + 'love'+'Python' + '\n') 第二种 通过逗号(,)的形式 print('第二种方式通过逗号形式连接 :' + 'love', 'Python' + '\n') 第三种 直接连接 中间有无空格均可 print('第三种方式通过直接连接形式连接 (一) :' + 'love''Python' + '\n') print('第三种方式通过直接连接形式连接 (二)

  • python字符串拼接的7种方法及性能比较详解

    python3.x拼接字符串一般有以下几种方法: 1. 直接通过(+)操作符拼接 s = 'Hello'+' '+'World'+'!' print(s) 输出结果: Hello World! 使用这种方式进行字符串连接的操作效率低下,因为python中使用 + 拼接两个字符串时会生成一个新的字符串,生成新的字符串就需要重新申请内存,当拼接字符串较多时自然会影响效率. 2. 通过str.join()方法拼接 strlist=['Hello',' ','World','!'] print(''.j

  • Python字符串拼接的4种方法实例

    目录 1. 算术运算符拼接 (1)+算术运算符 (2) * 算术运算符 2.format方法 3.百分号操作符 4.特殊符号f 附:常见字符串去除空格的方法总结 总结 在程序实际应用中,少不了要进行字符串拼接的操作.下面介绍一下Python语言中四种字符串拼接的方式. 1. 算术运算符拼接 在Python中算术运算符一共有七种种,分别是+.-.*././/.**和%.其中+和*不仅可以用来进行算数计算,也可以用来字符串拼接. (1)+算术运算符 +运算符在Python中可以用作数学计算,例如:

  • 详解MySQL批量入库的几种方式

    目录 1. MySQL批量入库概述 2. Hutool封装jdbc方式 测试环境准备 3. Jdbc直接或批量执行方式 4. MyBatis批量入库方式 5. MySQL批量入库总结 1. MySQL批量入库概述 最近压测一款mysql持久化工具,目前市面上mysql批量入库方式有很多,这里分别对常用的几种方式进行压测对比分析,比如列举了hutool工具封装的jdbc方式,jdbc直接执行与批量执行的方式,以及常用的mybatis方式. 2. Hutool封装jdbc方式 Hutool-db是一

  • 详解MySQL数据库优化的八种方式(经典必看)

    引言: 关于数据库优化,网上有不少资料和方法,但是不少质量参差不齐,有些总结的不够到位,内容冗杂. 偶尔发现了这篇文章,总结得很经典,文章流量也很大,所以拿到自己的总结文集中,积累优质文章,提升个人能力,希望对大家今后开发中也有帮助 1.选取最适用的字段属性 MySQL可以很好的支持大数据量的存取,但是一般说来,数据库中的表越小,在它上面执行的查询也就会越快.因此,在创建表的时候,为了获得更好的性能,我们可以将表中字段的宽度设得尽可能小. 例如,在定义邮政编码这个字段时,如果将其设置为CHAR(

  • String字符串截取的四种方式总结

    如下所示: import java.util.StringTokenizer; import java.util.regex.Pattern; import org.junit.Test; public class TestStringToken { @Test public void subSting() { String str = "java,javac,javae"; String s1 = str.substring(2);//"va,javac,javae&quo

  • js字符串引用的两种方式(必看)

    如下所示: function setName(obj) { obj.ok = "ccccccc"; } function aa() { var name = new String("hechangmin"); name.ok = "sdf"; //第一种方式 // String.prototype.ok = "aaaaa"; //第二种方式 alert(name.ok); // aaaaa setName(name); ale

  • Java字符串写入文件三种方式的实现

     Java字符串写入文件三种方式的实现 1.使用FileWriter String str="hello world!"; FileWriter writer; try { writer = new FileWriter("E:/token.txt"); writer.write(str); writer.flush(); writer.close(); } catch (IOException e) { e.printStackTrace(); } 2.使用Fil

随机推荐