sql字符串函数⼤全和使⽤⽅法⽰例
SQL SERVER⽀持的字符串函数内容:
复制代码代码如下:
LEN(string)函数
LOWER(string)函数
UPPER (string)函数
LTRIM(string)函数
RTRIM (string)函数
SUBSTRING(string,start_position,length)函数
CHARINDEX(string,substring)函数
LEFT (string,length)函数
RIGHT (string,length) 函数
ASCII(string)函数
ASCII(string)函数
(1)LEN(string)函数:此函数是⽤来计算⼀个字符串的长度,接受⼀个参数(可以为表⾥⾯的⼀个字符串字段,也可以为别的)。这⾥⾯,是没有区分⼤⼩写(下⾯的函数都⼀样)。LEN,len,还是Len都等同。例⼦如下:
SELECT FName, LEN(FName) FROM T_Person
注:如果给LEN函数传递的参数是⼀个时间字段的话,那么返回的结果就不对,⽐如⼀个DateTime。所以呢,这个函数是⽤来计算字符串的长度,别的类型参数也能返回结果,但是就不⼀定正确。
I、如果传进去的是NULL,那么返回出来的还是NULL。
II、对于⼀个字符串形如' a a ',返回的结果是4,⽽不是5。即计算的结果不包括右侧全为空格字符串部分。
(2)LOWER(string)函数:此函数是⽤来把⼀字符串都转换为⼩写字符串。跟LEN()函数⼀样,也接受⼀个参数。
复制代码代码如下:
SELECT FName, LOWER(FName) FROM T_Person
注:如果传进去的是NULL,那么返回出来的还是NULL。
(3)UPPER (string)函数:与LOWER()函数相反,此函数把字符串都转换为⼤写字符串。也同样接受⼀个参数。
复制代码代码如下:
SELECT FName, UPPER(FName) FROM T_Person
注:如果传进去的是NULL,那么返回出来的还是NULL。
(4)LTRIM(string)函数:此函数是去除字符串左边的空格(对于夹在字符串⾥⾯的空格则⽆能为⼒)。也同样接受⼀个参数。
复制代码代码如下:
SELECT FName,LTRIM(FName),LTRIM(' abc ') FROM T_Person
注:如果传进去的是NULL,那么返回出来的还是NULL。
(5)RTRIM (string)函数:此函数是去除字符串右边的空格(对于夹在字符串⾥⾯的空格则⽆能为⼒)。也同样接受⼀个参数。
复制代码代码如下:
SELECT FName,RTRIM(FName),RTRIM(' abc ') FROM T_Person
注:如果传进去的是NULL,那么返回出来的还是NULL。
如果需要去除两边的空格(对于夹在字符串⾥⾯的空格则⽆能为⼒),则需要联合来使⽤。
SELECT FName,LTRIM(RTRIM(FName)),LTRIM(RTRIM(' abc ')) FROM
T_Person
(6)SUBSTRING(string,start_position,length)函数:此函数是使⽤来获取⼦字符串。其中参数string为主字符
串,start_position为⼦字符串在主字符串中的起始位置,length
为⼦字符串的最⼤长度。需要注意的是这⾥的start_position是从1开始,不同于数组是从0开始。如果给的是0的话,相当于取了⼀个''。
复制代码代码如下:
SELECT FName, SUBSTRING(FName,2,3) FROM T_Person
注:如果传进去的是NULL,那么返回出来的还是NULL。
(7)CHARINDEX(substring,string)函数:此函数是计算⼦字符串在主字符串中位置。其中参数substring为⼦字符串,string 为主字符串。这个函数可以检测制定的⼦字符串是否存在于主字符串中,如果存在则还可以返回所在的位置。假如有匹配的话,结果⼤于0。也就是匹配成功的话,⾄少从1开始。
复制代码代码如下:
SELECT FName,CHARINDEX('m', FName), CHARINDEX('ly', FName)
FROM T_Person
注:如果传进去的是NULL,那么返回出来的还是NULL。
(8)LEFT (string,length)函数:此函数是实现从左侧开始取⼦字符串,其中参数string为主字符串,length为⼦字符串的最⼤长度。即取出来的结果是1⾄length范围内的⼦字符串。
复制代码代码如下:
SELECT FName, LEFT(FName,3) , LEFT(FName,2)
FROM T_Person
注:如果传进去的是NULL,那么返回出来的还是NULL。
这种⽅式等同于使⽤SUBSTRING(string,start_position,length)函数:
复制代码代码如下:
SELECT FName,SUBSTRING(FName, 1,3) FROM T_Person
(9)RIGHT (string,length) 函数:此函数是实现从右侧开始取⼦字符串,其中参数string为主字符串,length为⼦字符串的最⼤长度。即取出来的结果是1⾄length范围内的⼦字符串。
复制代码代码如下:
SELECT FName, RIGHT(FName,3) , RIGHT(FName,2)
F
ROM T_Person
注:如果传进去的是NULL,那么返回出来的还是NULL。
这种⽅式等同于使⽤SUBSTRING(string,start_position,length)函数,其中SUBSTRING(string, LEN(string)- length+1, length)等价于RIGHT (string,length)。
复制代码代码如下:
SELECT FName, SUBSTRING(FName,LEN(FNAME)-2,3) , SUBSTRING(FName,LEN(FNAME)-1,2)
FROM T_Person
(10)REPLACE(string,string_tobe_replace,string_to_replace)函数:此函数是实现字符串的替换功能,其中参数string 为要进⾏替换操作的主字符串,参数string_tobe_replace 为要被替换的字符串,即string_to_replace将替换string_tobe_replace中所有出现的地⽅。
select FName,REPLACE(FName,'i','e'),FIDNumber,
REPLACE(FIDNumber,'2345','abcd') FROM T_Person
借助替换为''来实现删除字符串的功能:
复制代码代码如下:
SELECT FName, REPLACE(FName,'m','') ,FIDNumber,字符串长度测量函数
REPLACE(FIDNumber,'123','') FROM T_Person
前⾯介绍过LTRIM(string)函数和RTRIM(string)函数,两者最终只能删除两侧的空格,⽽对于在字符串⾥⾯的空格,则⽆能为⼒。⽽借助于REPLACE函数则可以轻松解决。
复制代码代码如下:
SELECT REPLACE(' abc 123 wpf',' ','') , REPLACE(' ccw enet wcf f',' ','')
(11)ASCII(string)函数:此函数⽤来得到⼀个字符的ASCII 码,它有且只有⼀个参数,这个参数为待求ASCII码的字符,如果参数为⼀个字符串则函数返回第⼀个字符的ASCII码。
复制代码代码如下:
SELECT ASCII('a') , ASCII('abc')
注:如果传进去的是NULL或者是'',那么返回出来的是NULL。
(12)CHAR(string)函数:与(11)相反,此函数⽤来得到⼀个字符的ASCII 码。
复制代码代码如下:
SELECT CHAR(56) , CHAR(90) ,'a', CHAR( ASCII('a') )
注:如果传进去的是NULL,那么返回出来的是NULL。
(13)DIFFERENCE(string)函数:此函数⽤来⽐较两个字符串的发⾳相似度,它可以计算两个字符串的发⾳特征值,并且⽐较它们,然后返回⼀个0⾄4 之间的⼀个值来反映两个字符串的发⾳相似度,这个
值越⼤则表⽰两个字符串发⾳相似度越⼤。
复制代码代码如下:
SELECT DIFFERENCE(FName,'Merry') FROM T_Person
注:如果传进去的是NULL,那么返回出来的是NULL。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。