字串函式用於對字元和二進位制字元進行各種操作
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');