例说SQL SERVER 2008内置函数之字符串函数

浏览:
字体:
发布时间:2013-12-09 23:23:25
来源:

1 LTRIM与RTRIM

>>SQL查询实例

 

SELECT LTRIM('     I am 20 years old.     ') AS Result;SELECT RTRIM('     I am 20 years old.     ') AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

LTRIM函数返回删除了前导空格之后的字符表达式;RTRIM函数返回删除了尾随空格之后的字符表达式。

 

入参与返回值:

 

LTRIM与RTRIM函数的输入参数(实例中的' I am 20 years old. ')都是字符或者二进制数据的表达式,可以是变量,常量或者列。LTRIM与RTRIM函数的返回值都是varchar 或nvarchar类型的数据。

 

2 ASCII与CHAR

>>SQL查询实例

 

SELECT ASCII('A') AS Result;SELECT CHAR(65) AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

ASCII函数返回字符的ASCII代码值;CHAR函数将 ASCII 代码值转换为字符。

 

入参与返回值:

 

ASCII函数的入参为char类型表达式(实例中的'A'),返回值为int型的ASCII代码;ASCII函数的入参也可以是varchar类型的表达式,此时返回表达式中最左侧的字符的 ASCII 代码值。CHAR函数的入参(实例中的65)为0-255之间的整数,返回值为char(1)类型数据;当入参不在0-255之间时返回NULL。

 

3 UNICODE与NCHAR

>>SQL查询实例

 

SELECT UNICODE('α') AS Result;SELECT NCHAR(945) AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

UNICODE、NCHAR函数分别是ASCII()、CHAR()函数的Unicode等价函数。

 

入参及返回值:

 

UNICODE函数接收nchar 或 nvarchar 表达式(实例中的'α'),返回int型数据;CHAR()函数接收int型数据(实例中的945),返回nchar 或 nvarchar 类型数据。

 

 

4 SPACE

>>SQL查询实例

 

SELECT 'HI,'+SPACE(5)+'YL!' AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

返回由多个空格组成的字符串。

 

入参与返回值:

 

入参(实例中的5)为正整数,指示空格的个数;返回值为varchar类型数据。

 

注意:

 

当传入参数为负数时,返回NULL;当传入参数为空字符(串)或者含若干空格的字符串时,返回值是空串;当传入非空字符(串)时函数无法执行。

 

 

SELECT 'HI,'+SPACE(-1)+'YL!' AS Result;

 

/

 

SELECT 'HI,'+SPACE('')+'YL!' AS Result;

 

 

SELECT 'HI,'+SPACE('     ')+'YL!' AS Result;

 

/

5 CHARINDEX与PATINDEX

>>SQL查询实例

 

SELECT CHARINDEX('AB','This is AB,That is also AB.') AS Result;SELECT CHARINDEX('AB','This is AB,That is also AB.',10) AS Result;SELECT PATINDEX('%A%','This is AB,That is also AB.') AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

CHARINDEX函数在一个表达式str1中搜索另一个表达式str2并返回其起始位置;PATINDEX函数与CHARINDEX函数功能类似,也是在一个表达式中去搜索另一个表达式并返回其起始位置,只是增加了对通配符%的支持,及要查找的表达式必须是“%pattern%”的形式(这里的%不能省略)。

 

入参及返回值:

 

CHARINDEX函数含有3个入参; 的第一个入参为要查找的表达式str2(实例中的'AB');第二个入参为被搜索的表达式str1(实例中的'This is AB,That is also AB.');第三个入参为搜索的起始位置(实例中的10),也可以不指定,不指定时从头开始查找。 PATINDEX函数只含有两个参数,其意义与CHARINDEX的前两个参数的意义相同;两者的返回值均为表达式b的起始位置,为int型数据。

 

6 QUOTENAME

>>SQL查询实例

 

SELECT QUOTENAME('abcdef') AS Result;SELECT QUOTENAME('abcdef','"') AS Result;SELECT QUOTENAME('abcdef','''') AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

QUOTENAME函数在字符串的前后加上指定的分隔符号(未指定时就加上默认的方括号[])。

 

入参及返回值:

 

QUOTENAME函数的第一个参数为Unicode字符组成的字符串;第二个参数为用作分隔符的单字符字符串,可以是单引号 (')、方括号([]) 或者英文双引号 (")。返回值为nvarchar(258)类型数据。

 

 

7 STR

>>SQL查询实例

 

SELECT STR(1234.567890) AS Result;SELECT STR(1234.567890,6,2) AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

将数字数据转换成字符数据。

 

入参及返回值:

 

第一个参数为需要转换的数字数据(float)(实例中的1234.567890);第二个参数为转换成的字符数据的总长度(实例中的6),默认值为10;第三个参数为小数点右边的小数位数(实例中的2),必须小于等于16。 后两个参数可以不指定,第二个参数不指定时,取默认值取10,第三个参数不指定时,数字舍入为整数。 返回值为varchar类型数据。

 

 

8 SOUNDEX与DIFFERENCE

>>SQL查询实例

 

SELECT	SOUNDEX('Red') AS Result;SELECT SOUNDEX('Red') AS Soundex1, SOUNDEX('Read') AS Soundex2, DIFFERENCE('Red','Read') AS DiffResult;

 

>>查询执行结果

/

>>函数说明

功能:

 

SOUNDEX函数返回一个由四个字符组成的代码用于评估两个字符串的相似性。(关于SOUNDEX代码大家自己去研究吧) 而DIFFERENCE函数返回一个整数值,指示两个字符表达式的 SOUNDEX 值之间的差异。

 

入参及返回值:

 

SOUNDEX函数接收字符数据组成的表达式(实例中的'Red'),可以是常量、变量或者列,返回varchar类型数据;DIFFERENCE函数接收两个字符数据组成的表达式(实例中的'Red'与'Read'),返回int型数据表示两者之间的差异程度,返回的值从 0 到 4 不等。 0 表示几乎不同或完全不同;4 表示几乎相同或完全相同。

 

 

9 REPLACE

>>SQL查询实例

 

SELECT REPLACE('abcdefghicde','cd','123') AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

将字符串str1中的所有字符串str2替换成指定的字符串str3。

 

入参及返回值:

 

第一个参数为需要搜索的字符串str1(实例中的'abcdefghicde');第二个参数为要查找的字符串str2(实例中的'cd');第三个参数为替换字符串str3(实例中的'123');返回值为varchar或者nvarchar。 如果其中任何一个入参为varchar,则返回值为varchar;若有一个入参为nvarchar,则返回值为nvarchar;如果任何一个参数为NULL,则返回值为NULL。

 

 

10 STUFF

>>SQL查询实例

 

SELECT STUFF('abcdef', 3, 3, '123') AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

先将字符串str1从指定开始位置(start)删除指定长度(length)的字符,再从指定的开始位置(start)插入字符串str2。

 

入参及返回值:

 

第一个参数为字符串str1(实例中的'abcdef'),可以是常量、变量,也可以是字符列或者二进制数据列;第二个参数为指定的开始位置start(实例中的3),删除和插入操作都从这个位置开始;第三个参数为需要删除的字节数length;第四个参数为待插入的字符串str2,可以是常量,变量,也可以是字符列或者二进制数据列。函数返回修改后的字符串。

 

注意:

 

当start或length<0,则返回空字符串;当start>str1的长度,则返回空字符串;当length>str1的长度,则最多删除到str1的最后一个字符。

 

 

11 SUBSTRING

>>SQL查询实例

 

SELECT SUBSTRING('abcdef' ,2 , 3 )   AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

SUBSTRING可以从指定的字符str,二进制,文本或图像表达式中获取其中的一部分。(实例中以字符串为例)

 

入参及返回值:

 

第一个参数为指定的字符串str(实例中的'abcdef');第二个入参为返回字符的起始位置start(实例中的2);第三个参数为返回字符的长度length(实例中的3);这里的返回值为字符串。

 

注意:

 

当start<1时,起始位置则为字符串str的第一个字符,返回的字符数则是start+length-1的值与0这两者中的较大值。

 

 

SELECT SUBSTRING('abcdef' ,0 , 3 )   AS Result;

 

 

/

 

实例说明:此处start+length-1=0+3-1=2>0,则返回的字符数为2。

 

当start>字符串str的字符数,则返回一个长度为零的字符串。当start+length>字符串str的字符数,则返回起始位置为 start 的整个值表达式。

 

 

12 LEFT与RIGHT

>>SQL查询实例

 

SELECT LEFT('abcdefg',2)  AS Result;SELECT RIGHT('abcdefg',2)  AS Result; 

 

>>查询执行结果

/

>>函数说明

功能:

 

两者分别返回指定字符串str中最左边或者最右边指定个数(length)的字符。

 

入参和返回值:

 

两者的第一个参数均为指定的字符串str(实例中的'abcdefg'),第二个参数均为指定的字符个数length(实例中的2),只是一个从左取一个从右取。返回值为varchar或者nvarchar类型的数据。

 

 

13 UPPER与LOWER

>>SQL查询实例

 

SELECT UPPER('abcdefg') AS Result;SELECT LOWER('ABCDEFG') AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

两者分别将指定字符串str的小写字符转换成大写字符或者将大写字符转换成小写字符。

 

入参及返回值:

 

两者的入参均为字符数据表达式(实例中的abcdefg'和'ABCDEFG'),可以是常量,变量或者列。返回值为varchar或者nvarchar类型的数据。

 

 

14 REVERSE

>>SQL查询实例

 

SELECT REVERSE('abcdefg') AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

将输入字符串str进行逆序操作后再返回。

 

入参及返回值:

 

入参为字符数据表达式,可以是常量,变量或者列。返回值为varchar或者nvarchar类型的数据。

 

 

15 LEN

>>SQL查询实例

 

SELECT LEN('ABCDEFG') AS Result;

 

>>查询执行结果

/

>>函数说明

功能:

 

返回输入字符串str的字节数,不包含尾随的空格。

 

入参和返回值:

 

入参为字符数据表达式,可以是常量,变量或者列。返回值为int或者bigint(当输入字符串str为varchar(max)、nvarchar(max) 或 varbinary(max)时)类型的值。

 

 

>更多相关文章
24小时热门资讯
24小时回复排行
资讯 | QQ | 安全 | 编程 | 数据库 | 系统 | 网络 | 考试 | 站长 | 关于东联 | 安全雇佣 | 搞笑视频大全 | 微信学院 | 视频课程 |
关于我们 | 联系我们 | 广告服务 | 免责申明 | 作品发布 | 网站地图 | 官方微博 | 技术培训
Copyright © 2007 - 2024 Vm888.Com. All Rights Reserved
粤公网安备 44060402001498号 粤ICP备19097316号 请遵循相关法律法规
');})();