• MYSQL CONCAT函数


    MYSQL CONCAT函数

    concat

    • SQL CONCAT函数用于将两个字符串连接起来,形成一个单一的字符串。试试下面的例子:

      1. SQL> SELECT CONCAT('FIRST ', 'SECOND');
      2. +----------------------------+
      3. | CONCAT('FIRST ', 'SECOND') |
      4. +----------------------------+
      5. | FIRST SECOND               |
      6. +----------------------------+
      7. 1 row in set (0.00 sec)

    • 想要更详细了解CONCAT函数,考虑EMPLOYEE_TBL的表具有以下记录:

      1. SQL> SELECT * FROM employee_tbl;
      2. +------+------+------------+--------------------+
      3. | id   | name | work_date | daily_typing_pages |
      4. +------+------+------------+--------------------+
      5. |    1 | John | 2007-01-24 |                250 |
      6. |    2 | Ram | 2007-05-27 |                220 |
      7. |    3 | Jack | 2007-05-06 |                170 |
      8. |    3 | Jack | 2007-04-06 |                100 |
      9. |    4 | Jill | 2007-04-06 |                220 |
      10. |    5 | Zara | 2007-06-06 |                300 |
      11. |    5 | Zara | 2007-02-06 |                350 |
      12. +------+------+------------+--------------------+
      13. 7 rows in set (0.00 sec)

    • 现在,假设根据上述表要连接名员工ID和work_date,那么你可以使用下面的命令:

      1. SQL> SELECT CONCAT(id, name, work_date)
      2.   -> FROM employee_tbl;
      3. +-----------------------------+
      4. | CONCAT(id, name, work_date) |
      5. +-----------------------------+
      6. | 1John2007-01-24             |
      7. | 2Ram2007-05-27             |
      8. | 3Jack2007-05-06             |
      9. | 3Jack2007-04-06             |
      10. | 4Jill2007-04-06             |
      11. | 5Zara2007-06-06             |
      12. | 5Zara2007-02-06             |
      13. +-----------------------------+
      14. 7 rows in set (0.00 sec)

    concat_ws

    • 使用方法:

    • CONCAT_WS(separator,str1,str2,...)

    • CONCAT_WS() 代表 CONCAT With Separator ,是CONCAT()的特殊形式。第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。

    • 注意:

    • 如果分隔符为 NULL,则结果为 NULL。函数会忽略任何分隔符参数后的 NULL 值。如连接后以逗号分隔

      1. mysql> select concat_ws(',','11','22','33');+-------------------------------+
      2. | concat_ws(',','11','22','33') |
      3. +-------------------------------+
      4. | 11,22,33 |
      5. +-------------------------------+
      6. 1 row in set (0.00 sec)

    • 和MySQL中concat函数不同的是, concat_ws函数在执行的时候,不会因为NULL值而返回NULL

      1. mysql> select concat_ws(',','11','22',NULL);
      2. +-------------------------------+
      3. | concat_ws(',','11','22',NULL) |
      4. +-------------------------------+
      5. | 11,22 |
      6. +-------------------------------+
      7. 1 row in set (0.00 sec)

    group_concat

    • 完整的语法如下:

    • group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔符'])

      1. mysql> select * from aa;
      2. +------+------+
      3. | id| name |
      4. +------+------+
      5. |1 | 10|
      6. |1 | 20|
      7. |1 | 20|
      8. |2 | 20|
      9. |3 | 200   |
      10. |3 | 500   |
      11. +------+------+
      12. 6 rows in set (0.00 sec)

    • 以id分组,把name字段的值打印在一行,逗号分隔(默认)

      1. mysql> select id,group_concat(name) from aa group by id;
      2. +------+--------------------+
      3. | id| group_concat(name) |
      4. +------+--------------------+
      5. |1 | 10,20,20|
      6. |2 | 20 |
      7. |3 | 200,500|
      8. +------+--------------------+
      9. 3 rows in set (0.00 sec)

    • 以id分组,把name字段的值打印在一行,分号分隔

      1. mysql> select id,group_concat(name separator ';') from aa group by id;
      2. +------+----------------------------------+
      3. | id| group_concat(name separator ';') |
      4. +------+----------------------------------+
      5. |1 | 10;20;20 |
      6. |2 | 20|
      7. |3 | 200;500   |
      8. +------+----------------------------------+
      9. 3 rows in set (0.00 sec)

    • 以id分组,把去冗余的name字段的值打印在一行,逗号分隔

      1. mysql> select id,group_concat(distinct name) from aa group by id;
      2. +------+-----------------------------+
      3. | id| group_concat(distinct name) |
      4. +------+-----------------------------+
      5. |1 | 10,20|
      6. |2 | 20   |
      7. |3 | 200,500 |
      8. +------+-----------------------------+
      9. 3 rows in set (0.00 sec)

    • 以id分组,把name字段的值打印在一行,逗号分隔,以name排倒序

      1. mysql> select id,group_concat(name order by name desc) from aa group by id;
      2. +------+---------------------------------------+
      3. | id| group_concat(name order by name desc) |
      4. +------+---------------------------------------+
      5. |1 | 20,20,10   |
      6. |2 | 20|
      7. |3 | 500,200|
      8. +------+---------------------------------------+
      9. 3 rows in set (0.00 sec)

  • 相关阅读:
    《进阶篇第9章》学习vuex知识点后练习:把求和案例改成vuex模块化编码
    单点登录原理
    Go 微服务开发框架 DMicro 的设计思路
    从「百亿美金」跌落,这家自动驾驶公司落寞背后的故事
    Aspectj基础原理解析
    盘点一个使用Python自动化处理GPS、北斗经纬度数据实战(中篇)
    信息量 就是确定某件事发生需要的有效信息多少。不一定是数据的长度。
    如何实现Laravel 5.1 分页功能及自定义分页样式
    GBase 8c 角色属性
    作为比萨店老板,如何设计一个松耦合的比萨菜单-工厂模式应用
  • 原文地址:https://blog.csdn.net/Andrew_Chenwq/article/details/127046414