<转>Mysql 连接字符串函数CONCAT,concat_ws,GROUP_CONCAT(合并多个数组)使用总结
在Mysql中两个字符串相加不能用+号,加号是用来做数字相加的,在mysql中要连接字符串需要用CONCAT或者CONCAT_WS函数:
Mysql CONCAT函数
语法:
CONCAT(str1,str2...)
例如:
select OCNCAT('AB','CD')
将输出 ABCD
需要注意的是:
SELECT CONCAT('abc',NULL)
其中有一个字符串为NULL
时将输出NULL
Mysql 的CONCAT_WS函数
的CONCAT_WS函数()函数, 表示concat with separato(合并多个数组)r,即有分隔符的字符串连接
select concat_ws(',','11','22','33');
输出:
11,22,33
需注意concat_ws的参数(合并多个数组)中有null的话,并非都返回null,例如 concat_ws(',','ab',NULL)
将输出 ab
Mysql的GROUP_CONCAT()函数
从名字可以看出这个函数是一个聚合函数,在group语句中使用,可以将多行的字符串按分组整合成一个字符串。
语法:
GROUP_CONCAT([DISTINCT] expr [,expr ...][ORDER BY {unsigned_integer | col_name | expr}[ASC | DESC] [,col_name ...]][SEPARATOR str_val])
假定:有一张表是UserRole存储User对应Role关系,其有两列userId,RoleCode,我们可以通过GROUP_CONCAT来取出用逗号分隔的用户角色
select userId,GROUP_CONCAT(RoleCode SEPARATOR ',') from UserRole
需要注意,GROUP_CONCAT函数默认的最大可连接字符串的长度是1024,如果连接的字符串长度超过1024的话会被截断,不过我们可以通过设置group_concat_max_len的值来修改GROUP_CONCAT的最大长度。
例如:
SET SESSION group_concat_max_len= 99999;
select userId,GROUP_CONCAT(RoleCode SEPARATOR ',') from UserRole
posted on 2016-03-18 12:41 hahahahahai12 阅读(1641) 评论(0) 收藏 举报