您的位置:首页 > 数据库 > MySQL

MySQL中concat函数(连接字符串)、concat_ws函数

2016-10-18 18:32 375 查看
一、concat

MySQL的concat函数可以连接一个或者多个字符串

使用方法:
concat(str1,str2,…)  

返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。

注意:

如果所有参数均为非二进制字符串,则结果为非二进制字符串。 

如果自变量中含有任一二进制字符串,则结果为一个二进制字符串。

一个数字参数被转化为与之相等的二进制字符串格式;若要避免这种情况,可使用显式类型 cast,例如:

SELECT CONCAT(CAST("67" AS CHAR), "12")

select concat('10'); 结果:10

select concat('11','22','33'); 结果: 112233

MySQL的concat函数在连接字符串的时候,只要其中一个是NULL,那么将返回NULL; 而Oracle的concat函数连接的时候,只要有一个字符串不是NULL,就不会返回NULL

select concat('11','22',null);
结果: null

二、concat_ws

MySQL中concat_ws函数

使用方法: 
CONCAT_WS(separator,str1,str2,...)

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

select concat_ws(',','11','22','33'); 结果:  11,22,33

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

 select concat_ws(',','11','22',NULL);  结果: 11,22

三、group_concat

MySQL中group_concat函数

group_concat()可用来行转列,
Oracle没有这样的函数


完整的语法如下:
group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔符'])

SELECT
GROUP_CONCAT(sname) from student  结果: 班长,班迷,班迷 

name字段的值打印在一行,#分隔

SELECT
GROUP_CONCAT(sname separator '#') from student  结果是:班长#班迷#班迷

去除冗余的sname字段的值打印在一行

SELECT
GROUP_CONCAT(DISTINCT sname  separator '#') from hibernate2.student  

结果是: 班长#班迷

SELECT GROUP_CONCAT(sname order by sid desc ) from hibernate2.student 

结果是:班迷,班迷,班长

四、repeat

mysql的repeat()函数,用法如下

REPEAT(str,count) :str 表示要复制的字符串,count表示复制的份数

select repeat('ab',2); 结果是abab

五、space

SPACE(N) 函数,生成N个空格 


select space(3); 结果就是光标前有三个空格

六 、strcmp

STRCMP(STR1,STR2) 字符串比较函数,该函数和字符集有关系,默认区分大小写


若STR1和STR2相同,
则返回 0,
   若STR1小于STR2,   则返回 -1,
   若STR1大于STR2,   则返回 1

select
strcmp('abc','abc'); 结果是: 0

select
strcmp('a','ab'); 结果是-1

select
strcmp('abc','ab'); 结果是1
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: