Sql Server函式全解(一)字串函式

阿赫瓦里發表於2015-04-27

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

1.ASCII()函式

 ASCII(character_expression)函式用於返回字串表示式中最左側的ASCII程式碼值。引數character_expression必須是一個char或varchar型別的字串表示式。
eg: select ASCII('s'),ASCII('sql'),ASCII('1');
執行結果如圖:
字元's'的ASCII值為115,所以第一行和第二行返回結果相同,對於第三條語句中的純數字的字串,可以不用單引號括起來。

 

2.CHAR()函式

 CHAR(integer_expression)函式將整數型別的ASCII值轉換為對應的字元,integer_expression是一個介於0~255之間的整數。如果該整數表示式不在此範圍內,將返回null值。
eg: select CHAR(115),CHAR(49);
可以看到,這裡返回的值與ASCII函式的返回值正好相反.

3.LEFT()函式

  LEFT(character_expression,integer_expression)函式返回字串左邊開始指定個數的字串、字元或者二進位制資料表示式。character_expression是字串表示式,可以是常量,變數或欄位。integer_expression為整數,指定character_expression將返回的字元數。 
eg: select LEFT('football',4);
 函式返回字串“football”左邊開始的長度為4的子字串,結果為“foot”,可見索引從1開始。

4.RIGHT()函式

 與LEFT()函式相反,RIGHT(character_expression,integer_expression)返回字串character_expression最右邊integer_expression個字元。
eg: select RIGHT('football',4);
 函式返回字元竄"football"右邊開始的長度為4的字串,結果為“ball”,索引也是從1開始的。

5.LTRIM()函式

  LTRIM(character_expression)用於除去字串左邊多餘的空格,字元資料表示式character_expression是一個字串表示式,可以是常量,變數,也可以是字元欄位或者二進位制資料列。
eg: select '(' + ' book ' + ')', '(' +LTRIM( ' book ') + ')';
 對比兩個值,LTRIM只刪除字串左邊的空格,右邊的空格不會被刪除.

6.RTRIM()函式

  RTRIM(character_expression)用於除去字串右邊多餘的空格,字元資料表示式character_expression是一個字串表示式,可以是常量,變數,也可以是字元欄位或者二進位制資料列。
eg:  select '(' +' book ' +')','(' +RTRIM(' book ') +')';
 對比兩個值,LTRIM只刪除字串右邊的空格,左邊的空格不會被刪除.

7.STR()函式

 STR(float_expression [ , length [ , decimal ] ])函式用於將數值資料轉換為字元資料。float_expression是一個帶有小數點的近似數字(float)資料型別的表示式。length表示總長度。它包括小數點、符號、數字以及空格,預設值為10。decimal指定小數點後的位數,decimal必須小於或等於16。如果decimal大於16,則會截斷結果,使其保持小數點後有16為。
eg: select STR(3141.59,6,1),STR(123.45,2,2)
 第一條語句6個數字和一個小數點組成的數值3141.59轉換為長度為6的字串,數字的小數部分舍入為1個小數位,第二條語句中的表示式超出指定的總長度時,返回的字串為指定長度的兩個**。

8.字串逆序的函式REVERSE()

 REVERSE(s)將字串s反轉,返回的字串的順序和s的順序相反。
eg: select REVERSE('abc');
 由結果可以看到,字串“abc”經過REVERSE函式處理後,所有的字串順序被反轉,結果為“cba”;

9.計算字串的長度函式LEN(str)

 返回字元表示式中的字元數。如果字串中包含前導空格和尾隨空格,則函式將它們包含在內。LEN對相同的單位元組和雙位元組字串返回相同的值。
eg: select LEN('no'),LEN('日期'),LEN(12345);
 可以看到,LEN函式在對待英文字元和漢字字元時,返回的字串長度是相同的,一個漢字也算作一個字元。LEN函式在處理純數字也將其當作字串,但是純數字可以不實用引號.

10.匹配字串開始位置的函式CHARINDEX(str1,str,[start])

 CHARINDEX(str1,str,[start])函式返回子字串str1在字串str中的開始位置,start為搜尋的開始位置,如果指定start引數,則從指定位置開始搜尋;如果不指定start引數或者指定為0或者負值,則從字串開始位置搜尋。
 eg: select CHARINDEX('a','banana'),CHARINDEX('a','banana',4), CHARINDEX('na','banana', 4);

 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是指定要進行轉換的字串。
eg: select LOWER('BEAUTIFUL'),LOWER('Well');
由結果可以看到,經過LOWER()函式轉換之後,大寫字母都變成小寫了,小寫字母保持不變.

13.UPPER()函式

 UPPER(character_expression)將小寫字元資料轉換為大寫字元資料後返回字元表示式。character_expression指定要進行轉換的字串。
eg: select UPPER('black'),UPPER('Black');
 由結果可以看到,經過UPPER函式轉換後,小寫字母都變成了大寫,大寫字母保持不變。

14.替換函式REPLACE(s,s1,s2)

 REPLACE(s,s1,s2)使用字串s2替代字串s中的s1.
 eg: select REPLACE('xxx.sqlserver2012.com','x','w');
 EPLACE('xxx.sqlserver2012.com','x','w')將"xxx.sqlserver2012.com"字串中的'x'替換為'w'字元,結果為"www.sqlserver2012.com";

 

上面例子的整體程式碼:

--字串函式
--1.ASCII()函式
select ASCII('s'),ASCII('sql'),ASCII(1);
--2.CHAR()函式
select CHAR(115),CHAR(49);
--3.LEFT()函式
select LEFT('football',4);
--4.RIGHT()函式
select RIGHT('football',4);
--5.LTRIM()函式
select '(' +'  book  ' +')','(' +LTRIM('  book  ') +')';
--6.RTRIM()函式
select '(' +'  book  ' +')','(' +RTRIM('  book  ') +')';
--7.STR()函式
select STR(3141.59,6,1),STR(123.45,2,2);
--8.字串逆序的函式REVERSE()
select REVERSE('abc');
--9.計算字串的長度函式LEN(str)
select LEN('no'),LEN('日期'),LEN(12345);
--10.匹配字串開始位置的函式CHARINDEX(str1,str,[start])
select CHARINDEX('a','banana'),CHARINDEX('a','banana',4), 
CHARINDEX('na','banana', 4);
--11.SUBSTRING()函式
select SUBSTRING('breakfast',1,5), 
SUBSTRING('breakfast',LEN('breakfast')/2,LEN('breakfast'));
--12.LOWER()
select LOWER('BEAUTIFUL'),LOWER('Well');
--13.UPPER()函式
select UPPER('black'),UPPER('Black');
--14.替換函式REPLACE(s,s1,s2)
select REPLACE('xxx.sqlserver2012.com','x','w');

相關文章