Sql Server函式全解(1):字串函式

發表於2015-05-07

字串函式用於對字元和二進位制字元進行各種操作

1.ASCII()函式
ASCII(character_expression)函式用於返回字串表示式中最左側的ASCII程式碼值。引數character_expression必須是一個char或varchar型別的字串表示式。

執行結果如圖:
字元’s’的ASCII值為115,所以第一行和第二行返回結果相同,對於第三條語句中的純數字的字串,可以不用單引號括起來。

2.CHAR()函式
CHAR(integer_expression)函式將整數型別的ASCII值轉換為對應的字元,integer_expression是一個介於0~255之間的整數。如果該整數表示式不在此範圍內,將返回null值。

可以看到,這裡返回的值與ASCII函式的返回值正好相反.

3.LEFT()函式
LEFT(character_expression,integer_expression)函式返回字串左邊開始指定個數的字串、字元或者二進位制資料表示式。character_expression是字串表示式,可以是常量,變數或欄位。integer_expression為整數,指定character_expression將返回的字元數。

函式返回字串“football”左邊開始的長度為4的子字串,結果為“foot”,可見索引從1開始。

4.RIGHT()函式
與LEFT()函式相反,RIGHT(character_expression,integer_expression)返回字串character_expression最右邊integer_expression個字元。

函式返回字元竄”football”右邊開始的長度為4的字串,結果為“ball”,索引也是從1開始的。

5.LTRIM()函式
LTRIM(character_expression)用於除去字串左邊多餘的空格,字元資料表示式character_expression是一個字串表示式,可以是常量,變數,也可以是字元欄位或者二進位制資料列。

對比兩個值,LTRIM只刪除字串左邊的空格,右邊的空格不會被刪除.

6.RTRIM()函式
RTRIM(character_expression)用於除去字串右邊多餘的空格,字元資料表示式character_expression是一個字串表示式,可以是常量,變數,也可以是字元欄位或者二進位制資料列。

對比兩個值,LTRIM只刪除字串右邊的空格,左邊的空格不會被刪除.

7.STR()函式
STR(float_expression [ , length [ , decimal ] ])函式用於將數值資料轉換為字元資料。float_expression是一個帶有小數點的近似數字(float)資料型別的表示式。length表示總長度。它包括小數點、符號、數字以及空格,預設值為10。decimal指定小數點後的位數,decimal必須小於或等於16。如果decimal大於16,則會截斷結果,使其保持小數點後有16為。

第一條語句6個數字和一個小數點組成的數值3141.59轉換為長度為6的字串,數字的小數部分舍入為1個小數位,第二條語句中的表示式超出指定的總長度時,返回的字串為指定長度的兩個**。

回到頂部
8.字串逆序的函式REVERSE()
REVERSE(s)將字串s反轉,返回的字串的順序和s的順序相反。

由結果可以看到,字串“abc”經過REVERSE函式處理後,所有的字串順序被反轉,結果為“cba”;

9.計算字串的長度函式LEN(str)
返回字元表示式中的字元數。如果字串中包含前導空格和尾隨空格,則函式將它們包含在內。LEN對相同的單位元組和雙位元組字串返回相同的值。

可以看到,LEN函式在對待英文字元和漢字字元時,返回的字串長度是相同的,一個漢字也算作一個字元。LEN函式在處理純數字也將其當作字串,但是純數字可以不實用引號.

10.匹配字串開始位置的函式CHARINDEX(str1,str,[start])
CHARINDEX(str1,str,[start])函式返回子字串str1在字串str中的開始位置,start為搜尋的開始位置,如果指定start引數,則從指定位置開始搜尋;如果不指定start引數或者指定為0或者負值,則從字串開始位置搜尋。

CHARINDEX(‘a’,’banana’)返回字串’banana’中子字串‘a’ 第一次出現的位置,結果為2;
CHARINDEX(‘a’,’banana’,4)返回字串’banana’中從第4個位置開始子字串‘a’的位置,結果為4;
CHARINDEX(‘na’,’banana’, 4)返回從第4個位置開始子字串‘na’第一次出現的位置,結果為5

11.SUBSTRING()函式
SUBSTRING(value_expression,start_expression,length_expression)函式返回字元表示式,二進位制表示式,文字表示式或影象表示式的一部分。
value_expression是character、binary、text、ntext或image表示式。
start_expression指定返回字元的起始位置的整數或表示式。如果start_expression小於0,或生成錯誤並終止語句。如果 start_expression大於值表示式的字元數,將返回一個零長度的表示式。
length_expression是正整數或指定要返回的value_expression的字元數表示式。如果length_expression是負數,會生成錯誤並終止語句,如果start_expression與length_expression的總和大於value_expression中的字元數,則返回整個值表示式。
eg: select SUBSTRING (‘breakfast’1,5), SUBSTRING(‘breakfast’ , LEN(‘breakfast’)/2, LEN(‘breakfast’));
第一條語句返回從第一個位置開始長度為5的字串,結果為”break”,第二條語句返回整個字串的後半段字串,結果為”akfast”

12.LOWER()
LOWER(character_expression)將大寫字元資料轉換為小寫字元資料後返回字元表示式。character_expression是指定要進行轉換的字串。

由結果可以看到,經過LOWER()函式轉換之後,大寫字母都變成小寫了,小寫字母保持不變.

13.UPPER()函式
UPPER(character_expression)將小寫字元資料轉換為大寫字元資料後返回字元表示式。character_expression指定要進行轉換的字串。

由結果可以看到,經過UPPER函式轉換後,小寫字母都變成了大寫,大寫字母保持不變。

14.替換函式REPLACE(s,s1,s2)
REPLACE(s,s1,s2)使用字串s2替代字串s中的s1.

EPLACE(‘xxx.sqlserver2012.com’,’x’,’w’)將”xxx.sqlserver2012.com”字串中的’x’替換為’w’字元,結果為”www.sqlserver2012.com”;

上面例子的整體程式碼:

相關文章