MySQL CONCAT()函数用于将多个字符串连接成一个字符串,是最重要的mysql函数之一,下面就将为您详细介绍mysql CONCAT()函数,供您参考.

mysql CONCAT(str1,str2,…)
返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。或许有一个或多个参数。 如果所有参数均为非二进制字符串,则结果为非二进制字符串。 如果自变量中含有任一二进制字符串,则结果为一个二进制字符串。一个数字参数被转化为与之相等的二进制字符串格式;若要避免这种情况,可使用显式类型 cast, 例如: SELECT CONCAT(CAST(int_col AS CHAR), char_col)

mysql> SELECT CONCAT(‘My’, ‘S’, ‘QL’);
-> ‘MySQL’

mysql> SELECT CONCAT(‘My’, NULL, ‘QL’);
-> NULL

mysql> SELECT CONCAT(14.3);
-> ‘14.3’

mysql CONCAT_WS(separator,str1,str2,…)
CONCAT_WS() 代表 CONCAT With Separator ,是CONCAT()的特殊形式。   第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。如果分隔符为 NULL,则结果为 NULL。函数会忽略任何分隔符参数后的 NULL 值。

mysql> SELECT CONCAT_WS(‘,’,’First name’,’Second name’,’Last Name’);
-> ‘First name,Second name,Last Name’

mysql> SELECT CONCAT_WS(‘,’,’First name’,NULL,’Last Name’);
-> ‘First name,Last Name’

mysql CONCAT_WS()不会忽略任何空字符串。 (然而会忽略所有的 NULL)。

group_concat函数是典型的字符串连接函数,下面就为您介绍MySQL group_concat的语法,希望对您学习MySQL group_concat函数有所帮助。

MySQL  group_concat函数

完整的语法如下:

阿里云-推广AD

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

我的理解就是: 后面的 group by xx 分好组之后, 然后将组内的数据连接起来,默认是逗号

测试sql语句:

insert into role VALUES(1,1,’管理员’,1);
insert into role VALUES(2,1,’编辑’,2);
insert into role VALUES(3,1,’超级管理员’,3);
insert into role VALUES(4,2,’普通会员’,4);
insert into role VALUES(5,3,’高级会员’,5);

例子:

select userId,group_concat(role_name,’;’) from role group by userId;

result:

1  管理员;,编辑;,超级管理员;
2  普通会员;
3  高级会员;