MySQL中函数CONCAT 、CONCAT_WS、GROUP_CONCAT

CONCAT_WS

使用函数CONCAT_WS()。

使用语法为:

CONCAT_WS(separator,str1,str2,…)

CONCAT_WS() 代表 CONCAT With Separator ,是CONCAT()的特殊形式。

第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。
分隔符可以是一个字符串,也可以是其它参数。
如果分隔符为 NULL,则结果为 NULL。函数会忽略任何分隔符参数后的 NULL 值。但是CONCAT_WS()不会忽略任何空字符串。 (然而会忽略所有的 NULL)。

mysql> select concat_ws(',','x','y','z');
+----------------------------+
| concat_ws(',','x','y','z') |
+----------------------------+
| x,y,z                      |
+----------------------------+
1 row in set (0.00 sec)

CONCAT

CONCAT()函数用于将多个字符串连接成一个字符串。

mysql> select concat(',','x','y','z');
+-------------------------+
| concat(',','x','y','z') |
+-------------------------+
| ,xyz                    |
+-------------------------+
1 row in set (0.00 sec)

GROUP_CONCAT

如果我们想把下面的查询列表拼接成逗号(,) 分隔的字符串,怎么搞呢?

mysql> select a.id from article a limit 10;
+----+
| id |
+----+
|  1 |
|  2 |
|  3 |
|  4 |
|  5 |
|  6 |
|  7 |
|  8 |
|  9 |
| 10 |
+----+
10 rows in set (0.00 sec)

答案:使用GROUP_CONCAT


mysql> select group_concat(a.id) from article a where a.id in
 (select t.id from (select id from article limit 10) t  );
+----------------------+
| group_concat(a.id)   |
+----------------------+
| 1,2,3,4,5,6,7,8,9,10 |
+----------------------+
1 row in set (0.00 sec)

特别指出的是这里in后面的select子句的写法:

 (select t.id from (select id from article limit 10) t  )

这里要注意的是,我们不能直接这么写

mysql> select group_concat(a.id) from article a where a.id in (select a.id from article a limit 10);
ERROR 1235 (42000): This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery'

这也是mysql的子查询语法用起来不是那么“理所当然”的地方。

    原文作者:一个会写诗的程序员
    原文地址: https://www.jianshu.com/p/8a1d40fb0dd6
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞