SQL ServerSQL Server 常用函数使用办法(持续创新)

前面便想只要拿部分 SQL
的常用函数记录下来,不过一直尚未尽。。。嘿嘿。。。

截至今天就此到substring()这个函数,C# 里面这个方式从始值是 0,而 SQL
里面由始值是 1。傻傻分不清楚。。。

顿时篇博客当记录 SQL 的函数的使用方式,想到哪里用到乌就写到哪里。。。

 

SubString():用以截取指定字符串的方法。该方法来三个参数:

参数1:用于指定要操作的字符串。

参数2:用于指定要截取的字符串的开头位置,起始值为 1 。

参数3:用于指定要截取的长。

select substring('abcdef',1,3)    -- 返回 abc

select substring('123456321',0,2)    -- 返回 1,即第一位,最好不要这样做

Left():用以返回指定字符串中指定长度的左侧有。该方法起三三两两单参数:

参数1:用于指定要操作的字符串。

参数2:用于指定要回去的子字符串的长度。

select LEFT('abc123',3)        -- 返回 abc

select LEFT('左侧部分右侧部分',4)    -- 返回 左侧部分

Right():用于返回指定字符串中指定长度的右手有。该方法时有发生零星单参数:

参数1:用于指定要操作的字符串。

参数2:用于指定要回的子字符串的长度。

select RIGHT('abc123',3)        -- 返回 123

select RIGHT('左侧部分右侧部分',4)    -- 返回 右侧部分

CharIndex():用以返回指定字符串中指定子字符串出现的序曲位置。如果未找到就回来
0。该方法起少数单参数:

参数1:用于指定要开展查找的字符串。

参数2:用于指定用作检索的字符串。

select charindex('a','123a123')        -- 返回 4

select charindex('abc','123a123')    -- 返回 0

select charindex('abc','123abc123')    -- 返回 4

Stuff():用来去指定长度的字符,并当剔除的岗位插入新的字符/值。该方法起四单参数:

参数1:用于指定要操作的字符串。

参数2:用于指定要去字符的开场位置。

参数3:用于指定要删减字符的尺寸。

参数4:用于指定在去的职插入的新的字符串/值。

select stuff('123abc456',4,3,'ABC')        -- 返回 123ABC456

select stuff('123abc456',1,3,'')    -- 返回 abc456,用空字符串替代

 Len():用以返回指定文本的价值的长短。前导空格计算在内,尾随空格不计算在内。该方法有一个参数:

参数1:用于指定要操作的公文或字符串。

select len('123')    -- 返回 3

select len('字符串')    -- 返回 3

Difference():用于返回一个整数价,指示两独字符表达式的
SOUNDEX 值之间的出入。(即有限单字符串的相似度)那么什么是 SOUNDEX
值呢?先记在,下面轮到其了。

回到的价由 0 到 4 不齐:0 代表几乎不同或全不同,4
表示几乎千篇一律或完全相同。该方法起有限单参数:

参数1:用于指定要开展比对的率先独字符串 SOUNDEX 值 。

参数2:用于指定要进行比对的第二只字符串 SOUNDEX 值。

select difference('action','demo')        -- 返回 2

select difference('123456','整数')        -- 返回 4

Soundex():用来返回指定字符串的 SOUNDEX
值。SOUNDEX是一律栽语音算法,利用英文字的读音计算近似值,值由四个字符构成,第一单字符为英文字母,后三只呢数字。在拼音文字被有时见面来会念但无可知拼出正确字之情,可用
Soundex 做类似模糊匹配的功效。这里的歪曲匹配与 LIKE 不同。

算法简要说明:

-- 将英文字按以下规则替换(不使用第一个字符进行匹配,并且不使用对应值为 0 的英文字符的值)
    a e h i o u w y -> 0
    b f p v -> 1
    c g j k q s x z -> 2
    d t -> 3
    l -> 4
    m n -> 5
    r -> 6

使字符串中存在有一致对应数字之2个或上述之假名在同(例如 j 和
k),则去其他的,只保留1只。去除对应值为 0
的字符,只回前4个字节,不够用 0 填充。

select soundex('string')    -- 返回 S215

select soundex('str')    -- 返回 S210

select soundex('123')    -- 返回 0000

select soundex('字符串')    -- 返回 0000

PS:除英文字符以外的字符都将赶回 0000,所以地方的主意 Difference()
的第二单示例会返回4(表示完全相同)。

Lower():用于返回指定英文字符串的粗写形式的字符串。如果不也英文字符串,则归原值。该方法来一个参数:

参数1:用于指定要转换为多少写形式的字符串。

select lower('ABC')        -- 返回 abc

select lower('123')    -- 返回 123

Upper():用以返回指定英文字符串的很写形式之字符串。如果不为英文字符串,则赶回原值。该方法有一个参数:

参数1:用于指定要转移为那个写形式的字符串。

select upper('abc')        -- 返回 ABC

select upper('123')    -- 返回 123

Ltrim():用于返回去前导空格之后的字符串。该方法来一个参数:

参数1:用于指定要进行删除前导空格操作的字符串。

select ltrim('        123')        -- 返回 123

select ltrim('        好多空格')    -- 返回 好多空格

select len('        123')    -- 返回 11

select len(ltrim('        123'))  -- 返回 3

Rtrim():用以返回截断尾随空格之后的字符串。该方法起一个参数:

参数1:用于指定要拓展截断尾随空格操作的字符串。

select rtrim('123         ')        -- 返回 123

select len(rtrim('123         '))  -- 返回 3

Replace():据此第三单表达式替换第一单字符串表达式中出现的拥有第二独让定字符串表达式。该方法时有发生三个参数:

参数1:用于指定要操作的字符串,即给匹配的字符串。

参数2:用于指定要进行匹配的字符串。

参数3:用于指定用作替换存在的匹配项的字符串。

--把 abc 替换为 xxx 
select replace('123abc456','abc','xxx')        -- 返回 123xxx456

-- 用空字符串替换匹配项
select replace('123abc456','abc','')    -- 返回 123456

 Unicode():依据 Unicode
标准返回指定字符或字符串的第一单字符的整数值。该方法有一个参数:

参数1:用于指定要操作的字符或字符串。

select unicode('a')        -- 返回 97

select unicode('abc')    -- 返回 97,只返回第一个字符

NChar():根据 Unicode
标准返回指定整数值代码的 Unicode 字符。该方法来一个参数:

参数1:指定一个 Unicode 标准的整数值代码。

select nchar(97)    -- 返回 a

select nchar(65)    -- 返回 A

Char():以指定的 int
类型的值转换为 ASCII 代码。该方法来一个参数:

参数1:指定一个 int 类型的数值,值范围吗 0 至 255。返回 null
表示整数表达式不是当是限外。

select char(99)    -- 返回 c

select char(9)    -- Tab符

select char(10)    -- 换行符

select char(13)    -- 回车符

ASCII():返回指定字符或字符串的率先只字符的
ASCII 代码值。该方法来一个参数:

参数1:用于指定要操作的字符或字符串。

select ascii('A')    -- 返回 65

select ascii('a')    -- 返回 97

PS:ASCII()
用于操作单字节,双许节请使用 Unicode()。全角字符为双字节、中文字符为双字节。

示例:

select unicode('字符串')    -- 返回 23383

select nchar('23383')    -- 返回 字

select char('23383')    -- 返回 NULL

select ascii('字符串')    -- 返回 215

select nchar('215')    -- 返回 ×

select char('215')    -- 返回 NULL

select ascii('Kan')    -- 返回 75

select nchar('75')    -- 返回 K

select char('75')    -- 返回 K

Str():回来一个指定数值的顶效字符串。该方法来三个参数:

参数1:指定要操作的数值。

参数2:指定要回去字符串的长短。默认值为10,即不点名默认长度为10,不足用空字符填充。

参数3:要回来的粗数位数。默认值为0,即不点名就不保留小数,不足指定位数,用0补充。

select str(123.10)    -- 返回        123

select len(str(123.10))    -- 返回 10

select str(123.10,5)    -- 返回   123

select len(str(123.10,5))    -- 返回 5

select str(123.10,20,5)        -- 返回            123.10000

select len(str(123.10,20,5))    -- 返回 20

Space():用来返回指定数值长的空格字符串。该方法起一个参数:

参数1:指定返回空格字符串的尺寸。

select '1'+space(3)+'2'        -- 返回 1   2

select len('1'+space(3)+'2')    -- 返回 5

Reverse():用以对点名字符串进行反转,按照单个字符进行反转。该方法起一个参数:

参数1:指定要实行反转操作的字符串。

select reverse('123')    -- 返回 321

select reverse('abc')    -- 返回 cba

Replicate():用以返回一个针对点名字符串重复指定次数后底字符串。该方法来半点独参数:

参数1:用于指定要操作的字符串。

参数2:用于指定字符串重复的次数。如果为0,返回空字符串;如果也负数,则回
null。

select replicate('123',3)    -- 返回 123123123

select replicate('a',3)        -- 返回 aaa

Quotename():回到一个 Unicode
字符串,根据指定分隔符,返回一个管用的字符串标识符。该方法时有发生零星个参数:

参数1:用于指定要操作的字符串。

参数2:用于指定分隔符,可以是单引号(’)、左括如泣如诉([)、右括号(])、左右括号([])或对引号(”)。如果无指定,默认使用左右括号。

select quotename('123','[]')    -- 返回 [123]

select quotename('123','''')    -- 返回 '123'

select quotename('123','"')        -- 返回 "123"

select quotename('12[]3','[]')    -- 返回 [12[]]3],右括号加倍表示转义字符。

Patindex():回去指定字符串表达式中指定模式第一糟出现的序曲位置,未找到则回回0。该方法时有发生有限单参数:

参数1:指定要配合的字符串及相当模式。

参数2:指定要为匹配的字符串表达式。

select Patindex('abc','123abc456abc789')    -- 返回 0

select Patindex('abc','abc')    -- 返回 1

select Patindex('abc%','123abc456abc789')    -- 返回 0

select Patindex('%abc%','123abc456abc789')    -- 返回 4

select Patindex('%[abc]%','123abc456abc789')    -- 匹配字符串 abc 第一次出现的位置,返回 4

select Patindex('%[^abc]%','123abc456abc789')    -- 匹配不等于字符 a、b、c 的其他字符第一次出现的位置,返回 1

select Patindex('%[^abc]%','b123abc456abc789')    -- 匹配不等于字符 a、b、c 的其他字符第一次出现的位置,返回 2

Parsename():回对象名称的指定部分。
可检索的对象有包括对象名称、所有者名称、数据库名称与服务器名称。其实也可以用于截取字符串。该方法时有发生半点个参数:

参数1:要摸其指定部分之目标的称呼。此号可含蓄四组成部分:服务器名称、数据库名称、所有者名称和对象名称。

参数2:要回的对象有。只能为1交4之数值。1 = 对象名称;2 = 架构名称;3
= 数据库名称;4 = 服务器名称

select parsename('server.dbo.dbTest.table',1) tablename,
       parsename('server.dbo.dbTest.table',2) dbname,
       parsename('server.dbo.dbTest.table',3) schemaname,
       parsename('server.dbo.dbTest.table',4) servername

SQL Server 1

这种截取方式接近于字符串分割,不过这里是倒着截取的,所以在必然水平达到足用来字符串的截取。不过只有支持小数点(.)的分割,而且仅支持四位。

select parsename('192.168.1.1',4) col1,
       parsename('192.168.1.1',3) col2,
       parsename('192.168.1.1',2) col3,
       parsename('192.168.1.1',1) col4

SQL Server 2

Getdate():获取当前日期时。

select getdate()

SQL Server 3

Year():收获指定日期表达式的年景。该方法来一个参数:

参数1:指定要操作的日期表达式。

select year('2016-01-01')    -- 返回 2016

select year('2017-01-01 12:30:30')    -- 返回 2017

select year(getdate())    -- 返回 2017

Month():抱指定日期表达式的月份。该方法来一个参数:

参数1:指定要操作的日期表达式。

select month('2016-01-01')    -- 返回 1

select month('2017-10-01 12:30:30')    -- 返回 10

select month(getdate())    -- 返回 5

Day():得到指定日期表达式的日。该方法来一个参数:

参数1:指定要操作的日期表达式。

select day('2016-01-01')    -- 返回 1

select day('2017-10-03 12:30:30')    -- 返回 3

select day(getdate())    -- 返回 11

Isdate():用于判断指定的字符串表达式是否也日期。返回
1,表示指定字符串表达式是日期。返回
0,表示指定字符串表达式不是日期。该方法来一个参数:

参数1:用于指定要操作的字符串表达式。

select isdate('10/30/2017')        -- 月/日/年        返回 1

select isdate('30/10/2017')        -- 日/月/年        返回 0

select isdate('2017/10/30')        -- 年/月/日        返回 1

select isdate('02/29/2017')        --用于判断闰年,由于2017不是闰年,所以没有29     返回 0

select isdate('2017-01-01')        -- 返回 1

select isdate('2017-01-01 10:10:10')    -- 返回 1

select isdate('01-01-2017')        -- 返回 1

select isdate('01-01-2017 10:10:10')    -- 返回 1

Datename():回指定日期的指定日期的片的字符串。该方法起些许单参数:

参数1:指定返回指定日期的指定部分的字符串。可以吗产图备受的日期部分或者缩写。

参数2:指定要操作的日期字符串。

SQL Server 4

select datename(year,'2017-01-01 10:10:10')    -- 返回 2017
select datename(yyyy,'2017-01-01 10:10:10')    -- 返回 2017

select datename(month,'2017-01-01 10:10:10')    -- 返回 01
select datename(mm,'2017-01-01 10:10:10')    -- 返回 01

select datename(quarter,'2017-05-02 10:10:10')        -- 表示一年的第几个季度        返回 2
select datename(weekday,'2017-02-02 10:10:10')        -- 表示一周的星期几        返回 星期四
select datename(week,'2017-02-02 10:10:10')        -- 表示一年的第几周        返回 5
select datename(dayofyear,'2017-02-02 10:10:10')        -- 表示一年的第几天        返回 33

select datename(hh,'2017-01-01 10:30:25')    -- 返回 10

Datepart():回来指定日期的指定日期的片的平头。Datepart()
方法以及 Datename() 的主意运用方式接近,只不过 Datename()
方法返回的凡一个字符串,而 Datepart()
方法返回的是一个整数数值。该方法起少数只参数:

参数1:指定返回指定日期的指定部分的字符串。可以吧达到图中之日子有或缩写。

参数2:指定要操作的日子字符串。

select datepart(year,'2017-01-01 10:10:10')    -- 返回 2017
select datepart(yyyy,'2017-01-01 10:10:10')    -- 返回 2017

select datepart(month,'2017-01-01 10:10:10')    -- 返回 1
select datepart(mm,'2017-01-01 10:10:10')    -- 返回 1

select datepart(quarter,'2017-05-02 10:10:10')        -- 表示一年的第几个季度        返回 2
select datepart(weekday,'2017-02-02 10:10:10')        -- 表示一周的星期几,即一周的第几天,星期日为一周的第一天    返回 5
select datepart(week,'2017-02-02 10:10:10')        -- 表示一年的第几周        返回 5
select datepart(dayofyear,'2017-02-02 10:10:10')        -- 表示一年的第几天        返回 33

select datepart(hh,'2017-01-01 10:30:25')    -- 返回 10

 Coalesce():返所有参数中的首先独非空(not
null)表达式。该方式极其多足起 n 个参数,但是至少要生个别只参数。

SELECT COALESCE('abc','')    -- 返回 abc

SELECT COALESCE(NULL,'')    -- 返回 空字符串

SELECT COALESCE(null,null,'123','abc')    -- 返回 123

PS:这个函数是返第一个非空的值,所以参数里面要至少有一个非空的价。

ISNull():认清指定的表达式一是否也空(null),如果为空则返回表达式二的值,否则回表达式一的价值,类似于C#受之老三最先运算符。该方法有零星只参数:

参数1:指定要操作的表达式一。

参数2:指定要操作的表达式二。

select isnull('','123')        -- 返回 空字符串

select isnull(null,'123')        -- 返回 123

select isnull('123','abc')        -- 返回 123

select isnull(null,null)    -- 返回 null

 

相关文章