--本文为学习笔记,(《t_sql》作者:Robert Sheldon 译者:冯昀晖 来源:TT中国)

---------------------------------------

函数--字符串函数--截取字符串的值

select name,left(name,12) as a, --根据指定的字符串从左往右截取,格式:left(字符串表达式,字符数)

substring(name,9,4) as b,--“SUBSTRING”函数可以提取字符串的任意部分。

--substring(字符串表达式,指定从哪里开始截取,截取多长的字符串)

right(name,2) as c,--根据指定的字符串从右往左截取

rtrim(vv) as v -- RTRIM删除字符串右边的空格,LTRIM删除字符串左边的空格

from table_1 where id >1


函数--字符串函数--修改字符串的值

select replace(name,'Mountain','Mtn') as ReplaceName,--用来替换给定字符串值中指定的一组字符串为新的字符串 REPLACE(字符串表达式,被替换的字符串值,替换的新字符串值)

stuff(name,11,2,'X01' )as StuffName,

--“STUFF”,它的作用是按照给定的位置删除一组指定的字符,并插入一组新的字符。该函数有四个参数:STUFF(待操作的字符串表达式,待删除的字符串的起始位置,要删除字符的数量,要插入的字符串)

reverse(ProductNumber) as reverseNum,--“RESERVSE”的作用是把给定字符串按逆序排列

stuff(productnumber,1,2,replicate(0,3)) as replicatenum,--“REPLICATE(待处理的字符串值,重复次数)”,该函数可以把指定字符串值重复指定的次数

productline+space(4)+lower(productline) as lowerprodline --“SPACE”函数与“REPLICATE”函数类似,它返回一组空格。该函数有一个参数,指定返回的空格数量

--LOWER 把字符串中的大写字符转换为小写字符,UPPER 把字符串中的小写字符转换为大写字符

from table_2 where product_num=7


函数--字符串函数--转换字符串的值

select name+char(9)+str(makeflag) as product,--函数是“CHAR”,可以把一个ASCII码整数(从0到255)转换为字符,该函数只有一个参数(一个ASCII码整数值)。该函数在给你的字符串插入控制字符时非常方便,比如tab键(ASCII码为9),换行符号(ASCII码为10)或者回车符(ASCII码为13)

--T-SQL还支持“NCHAR”函数,它可以把Unicode整数转换为Unicode字符

--STR(待转换的数值型表达式),它可以把数值型数据转换为字符型数据,如果没有转换bit列就连接两个列,会显示一条错误信息。 实例里的makeflag就是bit列

ascii(makeflag) as ciimakeflag,--转换单个字符为ASCII码整数,这里是用“ASCII”函数转换“MakeFlag”值为整数

retim(style)as style,--很重要的一点是,要先用“RTRIM”函数删除字符串尾部的空格,因为“UNICODE”函数(与ASCII函数一样)一次只能转换一个字符

unicode(rtrim(style)as unicodestyle --UNICODE(unicode字符表达式),该函数用来把一个字符转换为Unicode整数,

from production.product where productid=77


函数--字符串函数--获取字符串的相关信息

select  len(description) as lengthdescriop,--返回指定字符串的字符数量

charindex('tecth',description) as charindexdescrip,--函数的功能是从某字符串中指定的开始位置查找某字符串所在位置,该函数有三个参数:CHARINDEX(要搜索的字符串,待搜索范围字符串,搜索开始的位置(可选))

patindex('%bike%',descripton) as patindexdescrip,--该函数在字符串中搜索第一次出现某字符串的位置。该函数有两个参数:PATINDEX(要匹配的字符串,在其中进行搜索的字符串)

from production.productdescription where productdescription_id=231


函数--字符串函数--对字符串执行“SOUNDEX”分析 

“SOUNDEX”是一种可以把字符值转换成四个字符构成编码的系统,目的是确定类似发音的单词。“SOUNDEX”函数返回的第一个字符与目标字符串的第一个字符串相同,后面三个字符是对辅音求值得到的数值代码。(元音被忽略,除非元音是第一个字母。) 

select @name1 as name1,@name2 as name2,--eg:name1=Allen,name2=Alan

soundex(@name1) as soundexname1,soundex(@name2) as soundexname2,--SOUNDEX(待分析的字符串)

difference(@name1,@name2) as soundexdiff --“DEFFERENCE”函数有两个参数,这两个参数就是待比较的字符串,返回结果是一个整数,表示两个字符串之间差异的程度。返回的整数结果可以是0到4之间的值。值0表示两个字符串之间几乎没有相似之处,而值4表示两个字符串非常相似