• 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)

  • 相关阅读:
    log4j2漏洞复现以及解决方案
    ACDSee Photo Studio Ultimate 2024特别版(图片编辑器)
    金仓数据库KingbaseES服务器应用参考手册--13. kingbase
    AI在医疗保健领域:突破界限,救治生命
    【干活分享-年薪百万以上】Java高端人才应具备的能力
    RFID电网资产全寿命周期管理解决方案
    ai神经网络滤镜安装包,ps神经网络滤镜安装包
    几行代码实现用Python输出表情包
    JavaIO系列——BufferedReader,BufferedWriter,PrintWriter,转换流
    【torch-sparse及pytorch-geometric 安装】
  • 原文地址:https://blog.csdn.net/Andrew_Chenwq/article/details/127046414