SQLServer記錄經常使用函數(轉)

> 文章轉載自
SQL Server 經常使用函數使用方法(持續更新) https://www.cnblogs.com/Brambling/p/6779434.html


 

SubString():用於截取指定字符串的方法。該方法有三個參數:html

參數1:用於指定要操做的字符串。算法

參數2:用於指定要截取的字符串的起始位置,起始值爲 1 。數據庫

參數3:用於指定要截取的長度。服務器

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

select substring('123456321',0,2)    -- 返回 1,即第一位,最好不要這樣作

Left():用於返回指定字符串中指定長度的左側部分。該方法有兩個參數:架構

參數1:用於指定要操做的字符串。函數

參數2:用於指定要返回的子字符串的長度。spa

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

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

Right():用於返回指定字符串中指定長度的右側部分。該方法有兩個參數:code

參數1:用於指定要操做的字符串。server

參數2:用於指定要返回的子字符串的長度。htm

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

這種截取方式相似於字符串分割,不過這裏是倒着截取的,因此在必定程度上能夠用於字符串的截取。不過只支持小數點(.)的分割,並且只支持四位。

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

Getdate():獲取當前日期時間。

select getdate()

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:指定要操做的日期字符串。

複製代碼
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
複製代碼

 












文章轉載自

SQL Server 經常使用函數使用方法(持續更新)
http://www.javashuo.com/article/p-duzhlqbv-cg.html

相關文章
相關標籤/搜索