SQL Server函數(shù)大全
創(chuàng)新互聯(lián)專注于鎮(zhèn)坪企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè)公司,商城系統(tǒng)網(wǎng)站開發(fā)。鎮(zhèn)坪網(wǎng)站建設(shè)公司,為鎮(zhèn)坪等地區(qū)提供建站服務(wù)。全流程按需定制,專業(yè)設(shè)計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務(wù)SQL Server中的函數(shù)對于提高查詢的工作效率起到了非常突出的作用。善于在查詢工作或開發(fā)工作中利用好SQL函數(shù),將對工作有很大的幫助,同時也會大大提升工作的效率。但是由于SQL函數(shù)種類眾多。所以在使用的時候往往會無法全部理解它們的含義和用法。下面將詳細對SQL函數(shù)的含義和使用方法做一個比較系統(tǒng)的介紹:
在實際工作中,select語句中只能使用SQL函數(shù)對字段進行操作,常見的函數(shù)可以分為以下幾大類:
1、字符轉(zhuǎn)換函數(shù)
1)ASCII()
返回字符表達式最左端字符的ASCII 碼值。在ASCII()函數(shù)中,純數(shù)字的字符串可不用‘’括起來,但含有其它字符的字符串必須用‘’括起來使用,否則會出錯。
2)CHAR()
將ASCII 碼轉(zhuǎn)換為字符。如果沒有輸入0 ~ 255 之間的ASCII 碼值,CHAR() 返回NULL 。
3)LOWER()和UPPER()
LOWER()將字符串全部轉(zhuǎn)為小寫;UPPER()將字符串全部轉(zhuǎn)為大寫。
4)STR()
把數(shù)值型數(shù)據(jù)轉(zhuǎn)換為字符型數(shù)據(jù)。
STR (
length 指定返回的字符串的長度,decimal 指定返回的小數(shù)位數(shù)。如果沒有指定長度,缺省的length 值為10, decimal 缺省值為0。
在length 或者decimal 為負值時,返回NULL;
在length 小于小數(shù)點左邊(包括符號位)的位數(shù)時,返回length 個*;
先服從length ,再取decimal ;
當返回的字符串位數(shù)小于length ,左邊補足空格。
2、去空格函數(shù)
1)LTRIM() 去除字符串頭部的空格。
2)RTRIM() 去除字符串尾部的空格。
3、字符串比較函數(shù)
1)CHARINDEX()
返回字符串中某個指定的子串所出現(xiàn)的開始位置。
CHARINDEX (<’substring_expression’>,
其中substring _expression 是所要查找的字符表達式,expression可為字符串也可為列名表達式。如果沒有發(fā)現(xiàn)子串,則返回0 值。
此函數(shù)不能用于TEXT和IMAGE數(shù)據(jù)類型。
2)PATINDEX()
返回字符串中某個指定的子串出現(xiàn)的開始位置。
PATINDEX (<’%substring _expression%’>,
與CHARINDEX 函數(shù)不同的是,PATINDEX函數(shù)的子串中可以使用通配符,且此函數(shù)可用于CHAR、 VARCHAR 和TEXT數(shù)據(jù)類型。
4、字符串操作函數(shù)
1)QUOTENAME()
返回被特定字符括起來的字符串。
QUOTENAME (<’character_expression’>[, quote_ character]) 其中quote_ character 標明括起來的字符串所用的字符,缺省值為“[]”。
2)REPLICATE()
返回一個重復character_expression指定次數(shù)的字符串。
REPLICATE (character_expression integer_expression) 如果integer_expression 值為負值,則返回NULL 。
3)REVERSE()
將指定的字符串的字符排列順序顛倒。
REVERSE (
4)REPLACE()
返回被替換了指定子串的字符串。
REPLACE (
5)SPACE()
返回一個有指定長度的空白字符串。
SPACE (
6)STUFF()
用另一子串替換字符串指定位置、長度的子串。
STUFF (
如果起始位置為負或長度值為負,或者起始位置大于character_expression1 的長度,則返回NULL 值。
如果length 長度大于character_expression1 中 start_ position 以右的長度,則character_expression1 只保留首字符。
5、取子串函數(shù)
1)left()
LEFT (
返回character_expression 左起 integer_expression個字符。
2)RIGHT()
RIGHT (
返回character_expression 右起 integer_expression個字符。
6、數(shù)據(jù)類型轉(zhuǎn)換函數(shù)
1)CAST()
CAST (
2)CONVERT()
CONVERT (
a)data_type為SQL Server系統(tǒng)定義的數(shù)據(jù)類型,用戶自定義的數(shù)據(jù)類型不能在此使用。
b)length用于指定數(shù)據(jù)的長度,缺省值為30。
c)把CHAR或VARCHAR類型轉(zhuǎn)換為諸如INT或SAMLLINT這樣的INTEGER類型、結(jié)果必須是帶正號或負號的數(shù)值。
d)TEXT類型到CHAR或VARCHAR類型轉(zhuǎn)換最多為8000個字符,即CHAR或VARCHAR數(shù)據(jù)類型是大長度。
e)IMAGE類型存儲的數(shù)據(jù)轉(zhuǎn)換到BINARY或VARBINARY類型,最多為8000個字符。
f)把整數(shù)值轉(zhuǎn)換為MONEY或SMALLMONEY類型,按定義的國家的貨幣單位來處理,如人民幣、美元、英鎊等。
g)BIT類型的轉(zhuǎn)換把非零值轉(zhuǎn)換為1,并仍以BIT類型存儲。
h)試圖轉(zhuǎn)換到不同長度的數(shù)據(jù)類型,會截短轉(zhuǎn)換值并在轉(zhuǎn)換值后顯示“+”,以標識發(fā)生了這種截斷。
i)用CONVERT()函數(shù)的style 選項能以不同的格式顯示日期和時間。style 是將DATATIME 和SMALLDATETIME數(shù)據(jù)轉(zhuǎn)換為字符串時所選用的由SQL Server系統(tǒng)提供的轉(zhuǎn)換樣式編號,不同的樣式編號有不同的輸出格式。
7、日期函數(shù)
1)day(date_expression)
返回date_expression中的日期值
2)month(date_expression)
返回date_expression中的月份值
3)year(date_expression)
返回date_expression中的年份值
4)DATEADD()
DATEADD (
返回指定日期date 加上指定的額外日期間隔number 產(chǎn)生的新日期。
5)DATEDIFF()
DATEDIFF (
返回兩個指定日期在datepart 方面的不同之處,即date2 超過date1的差距值,其結(jié)果值是一個帶有正負號的整數(shù)值。
6)DATENAME()
DATENAME (
以字符串的形式返回日期的指定部分此部分。由datepart 來指定。
7)DATEPART()
DATEPART (
以整數(shù)值的形式返回日期的指定部分。此部分由datepart 來指定。
DATEPART (dd, date) 等同于DAY (date)
DATEPART (mm, date) 等同于MONTH (date)
DATEPART (yy, date) 等同于YEAR (date)
8)GETDATE()
8、用戶自定義函數(shù)
1)標量自定義函數(shù)
有一個確定的返回值
格式:Create function function_name [inputparameters]
Returns datatype
AS
Begin
code
return expression
End
調(diào)用方法:Select dbo.函數(shù)名
2)內(nèi)嵌表函數(shù)
格式:Creae function function_name (inputparameters)
Returns table
AS
Return (select code)
以DATETIME 的缺省格式返回系統(tǒng)當前的日期和時間。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。