1. 程式人生 > 其它 >SQL Server系統函式

SQL Server系統函式

轉自:https://www.cnblogs.com/jojomeme/archive/2012/04/05/2433173.html

一、字元轉換函式
1、ASCII()
返回字元表示式最左端字元的ASCII 碼值。在ASCII()函式中,純數字的字串可不用‘’括起來,但含其它字元的字串必須用‘’括起來使用,否則會出錯。
2、CHAR()
將ASCII 碼轉換為字元。如果沒有輸入0 ~ 255 之間的ASCII 碼值,CHAR() 返回NULL 。
3、LOWER()和UPPER()
LOWER()將字串全部轉為小寫;UPPER()將字串全部轉為大寫。
4、STR()
把數值型資料轉換為字元型資料。
STR (<float_expression>[,length[, <decimal>]])
length 指定返回的字串的長度,decimal 指定返回的小數位數。如果沒有指定長度,預設的length 值為10, decimal 預設值為0。
當length 或者decimal 為負值時,返回NULL;
當length 小於小數點左邊(包括符號位)的位數時,返回length 個*;
先服從length ,再取decimal ;
當返回的字串位數小於length ,左邊補足空格。

二、去空格函式

1、LTRIM() 把字串頭部的空格去掉。
2、RTRIM() 把字串尾部的空格去掉。
三、取子串函式
1、left() 
LEFT (<character_expression>, <integer_expression>)
返回character_expression 左起 integer_expression 個字元。
2、RIGHT() 
RIGHT (<character_expression>, <integer_expression>)
返回character_expression 右起 integer_expression 個字元。
3、SUBSTRING()
SUBSTRING (<expression>, <starting_ position>, length)
返回從字串左邊第starting_ position 個字元起length個字元的部分。

四、字串比較函式

1、CHARINDEX()
返回字串中某個指定的子串出現的開始位置。
CHARINDEX (<’substring_expression’>, <expression>)
其中substring _expression 是所要查詢的字元表示式,expression 可為字串也可為列名錶達式。如果沒有發現子串,則返回0 值。
此函式不能用於TEXT 和IMAGE 資料型別。
2、PATINDEX()
返回字串中某個指定的子串出現的開始位置。
PATINDEX (<’%substring _expression%’>, <column_ name>)其中子串表示式前後必須有百分號“%”否則返回值為0。
與CHARINDEX 函式不同的是,PATINDEX函式的子串中可以使用萬用字元,且此函式可用於CHAR、 VARCHAR 和TEXT 資料型別。
五、字串操作函式

1、QUOTENAME()
返回被特定字元括起來的字串。
QUOTENAME (<’character_expression’>[, quote_ character]) 其中quote_ character 標明括字串所用的字元,預設值為“[]”。
2、REPLICATE()
返回一個重複character_expression 指定次數的字串。
REPLICATE (character_expression integer_expression) 如果integer_expression 值為負值,則返回NULL 。
3、REVERSE()
將指定的字串的字元排列順序顛倒。
REVERSE (<character_expression>) 其中character_expression 可以是字串、常數或一個列的值。
4、REPLACE()
返回被替換了指定子串的字串。
REPLACE (<string_expression1>, <string_expression2>, <string_expression3>) 用string_expression3 替換在string_expression1 中的子串string_expression2。
5、SPACE()
返回一個有指定長度的空白字串。
SPACE (<integer_expression>) 如果integer_expression 值為負值,則返回NULL 。
6、STUFF()
用另一子串替換字串指定位置、長度的子串。
STUFF (<character_expression1>, <start_ position>, <length>,<character_expression2>)
如果起始位置為負或長度值為負,或者起始位置大於character_expression1 的長度,則返回NULL 值。
如果length 長度大於character_expression1 中 start_ position 以右的長度,則character_expression1 只保留首字元。

六、資料型別轉換函式
1、CAST()
CAST (<expression> AS <data_ type>[ length ])
2、CONVERT()
CONVERT (<data_ type>[ length ], <expression> [, style])
1)data_type為SQL Server系統定義的資料型別,使用者自定義的資料型別不能在此使用。
2)length用於指定資料的長度,預設值為30。
3)把CHAR或VARCHAR型別轉換為諸如INT或SAMLLINT這樣的INTEGER型別、結果必須是帶正號或負號的數值。
4)TEXT型別到CHAR或VARCHAR型別轉換最多為8000個字元,即CHAR或VARCHAR資料型別是最大長度。
5)IMAGE型別儲存的資料轉換到BINARY或VARBINARY型別,最多為8000個字元。
6)把整數值轉換為MONEY或SMALLMONEY型別,按定義的國家的貨幣單位來處理,如人民幣、美元、英鎊等。
7)BIT型別的轉換把非零值轉換為1,並仍以BIT型別儲存。
8)試圖轉換到不同長度的資料型別,會截短轉換值並在轉換值後顯示“+”,以標識發生了這種截斷。
9)用CONVERT()函式的style 選項能以不同的格式顯示日期和時間。style 是將DATATIME 和SMALLDATETIME 資料轉換為字串時所選用的由SQL Server 系統提供的轉換樣式編號,不同的樣式編號有不同的輸出格式。
七、日期函式
1、day(date_expression) 
返回date_expression中的日期值
2、month(date_expression)
返回date_expression中的月份值
3、year(date_expression)
返回date_expression中的年份值
4、DATEADD()
DATEADD (<datepart>, <number>, <date>)
返回指定日期date 加上指定的額外日期間隔number 產生的新日期。
5、DATEDIFF()
DATEDIFF (<datepart>, <date1>, <date2>)
返回兩個指定日期在datepart 方面的不同之處,即date2 超過date1的差距值,其結果值是一個帶有正負號的整數值。
6、DATENAME()
DATENAME (<datepart>, <date>)
以字串的形式返回日期的指定部分此部分。由datepart 來指定。
7、DATEPART()
DATEPART (<datepart>, <date>)
以整數值的形式返回日期的指定部分。此部分由datepart 來指定。
DATEPART (dd, date) 等同於DAY (date)
DATEPART (mm, date) 等同於MONTH (date)
DATEPART (yy, date) 等同於YEAR (date)
8、GETDATE()
以DATETIME 的預設格式返回系統當前的日期和時間。

八、統計函式

AVG ( ) -返回的平均價值
count( ) -返回的行數
first( ) -返回第一個值
last( ) -返回最後一個值
max( ) -返回的最大價值
min( ) -返回最小的價值
total( ) -返回的總和

九、數學函式
abs(numeric_expr)                   求絕對值
ceiling(numeric_expr)                取大於等於指定值的最小整數
exp(float_expr)                      取指數
floor(numeric_expr)                   小於等於指定值得最大整數
pi()                                  3.1415926.........
power(numeric_expr,power)            返回power次方      
rand([int_expr])                     隨機數產生器
round(numeric_expr,int_expr)         安int_expr規定的精度四捨五入
sign(int_expr)                      根據正數,0,負數,,返回+1,0,-1
sqrt(float_expr)                     平方根

十、系統函式
suser_name()       使用者登入名
user_name()        使用者在資料庫中的名字
user               使用者在資料庫中的名字
show_role()        對當前使用者起作用的規則
db_name()          資料庫名                    
object_name(obj_id) 資料庫物件名     
col_name(obj_id,col_id) 列名       
col_length(objname,colname)  列長度
valid_name(char_expr)     是否是有效識別符號

追加:
排名函式是SQL Server2005新加的功能。在SQL Server2005中有如下四個排名函式:
1. row_number
2. rank
3. dense_rank
4. ntile   
    下面分別介紹一下這四個排名函式的功能及用法。在介紹之前假設有一個t_table表,表結構與表中的資料如圖1所示:



其中field1欄位的型別是int,field2欄位的型別是varchar

一、row_number

    row_number函式的用途是非常廣泛,這個函式的功能是為查詢出來的每一行記錄生成一個序號。row_number函式的用法如下面的SQL語句所示: 

select row_number() over(order by field1) as row_number,* from t_table

  

    其中row_number列是由row_number函式生成的序號列。在使用row_number函式是要使用over子句選擇對某一列進行排序,然後才能生成序號。

    實際上,row_number函式生成序號的基本原理是先使用over子句中的排序語句對記錄進行排序,然後按著這個順序生成序號。over子句中的order by子句與SQL語句中的order by子句沒有任何關係,這兩處的order by 可以完全不同,如下面的SQL語句所示: 

select row_number() over(order by field2 desc) as row_number,* from t_table order by field1 desc       我們可以使用row_number函式來實現查詢表中指定範圍的記錄,一般將其應用到Web應用程式的分頁功能上。下面的SQL語句可以查詢t_table表中第2條和第3條記錄: with t_rowtable
as
(
    select row_number() over(order by field1) as row_number,* from t_table
)
select * from t_rowtable where row_number>1 and row_number < 4 order by field1       上面的SQL語句使用了CTE,關於CTE的介紹將讀者參閱《SQL Server2005雜談(1):使用公用表表達式(CTE)簡化巢狀SQL》
    另外要注意的是,如果將row_number函式用於分頁處理,over子句中的order by 與排序記錄的order by 應相同,否則生成的序號可能不是有續的。
    當然,不使用row_number函式也可以實現查詢指定範圍的記錄,就是比較麻煩。一般的方法是使用顛倒Top來實現,例如,查詢t_table表中第2條和第3條記錄,可以先查出前3條記錄,然後將查詢出來的這三條記錄按倒序排序,再取前2條記錄,最後再將查出來的這2條記錄再按倒序排序,就是最終結果。SQL語句如下:  select * from (select top 2 * from( select top 3 * from t_table order by field1) a order by field1 desc) b order by field1                                                                
    上面的SQL語句查詢出來的結果如圖5所示。 

    這個查詢結果除了沒有序號列row_number,其他的與圖4所示的查詢結果完全一樣。

二、rank

    rank函式考慮到了over子句中排序欄位值相同的情況,為了更容易說明問題,在t_table表中再加一條記錄,如圖6所示。
                        
    在圖6所示的記錄中後三條記錄的field1欄位值是相同的。如果使用rank函式來生成序號,這3條記錄的序號是相同的,而第4條記錄會根據當前的記錄 數生成序號,後面的記錄依此類推,也就是說,在這個例子中,第4條記錄的序號是4,而不是2。rank函式的使用方法與row_number函式完全相 同,SQL語句如下: 

select rank() over(order by field1),* from t_table order by field1
                                                                   

    上面的SQL語句的查詢結果如圖7所示。 

三、dense_rank

    dense_rank函式的功能與rank函式類似,只是在生成序號時是連續的,而rank函式生成的序號有可能不連續。如上面的例子中如果使用dense_rank函式,第4條記錄的序號應該是2,而不是4。如下面的SQL語句所示:

select dense_rank() over(order by field1),* from t_table order by field1

    上面的SQL語句的查詢結果如圖8所示。

    讀者可以比較圖7和圖8所示的查詢結果有什麼不同

四、ntile
    ntile函式可以對序號進行分組處理。這就相當於將查詢出來的記錄集放到指定長度的陣列中,每一個數組元素存放一定數量的記錄。ntile函式為每條記 錄生成的序號就是這條記錄所有的陣列元素的索引(從1開始)。也可以將每一個分配記錄的陣列元素稱為“桶”。ntile函式有一個引數,用來指定桶數。下 面的SQL語句使用ntile函式對t_table表進行了裝桶處理:

select ntile(4) over(order by field1) as bucket,* from t_table

    上面的SQL語句的查詢結果如圖9所示。 

    由於t_table表的記錄總數是6,而上面的SQL語句中的ntile函式指定了桶數為4。

    也許有的讀者會問這麼一個問題,SQL Server2005怎麼來決定某一桶應該放多少記錄呢?可能t_table表中的記錄數有些少,那麼我們假設t_table表中有59條記錄,而桶數是5,那麼每一桶應放多少記錄呢?

    實際上通過兩個約定就可以產生一個演算法來決定哪一個桶應放多少記錄,這兩個約定如下:

1. 編號小的桶放的記錄不能小於編號大的桶。也就是說,第1捅中的記錄數只能大於等於第2桶及以後的各桶中的記錄。

2. 所有桶中的記錄要麼都相同,要麼從某一個記錄較少的桶開始後面所有捅的記錄數都與該桶的記錄數相同。也就是說,如果有個桶,前三桶的記錄數都是10,而第4捅的記錄數是6,那麼第5桶和第6桶的記錄數也必須是6。

    根據上面的兩個約定,可以得出如下的演算法:

    // mod表示取餘,div表示取整 
    if(記錄總數 mod 桶數 == 0)
    {
        recordCount = 記錄總數 div 桶數;
        將每桶的記錄數都設為recordCount
    } 
    else
    {
        recordCount1 = 記錄總數 div 桶數 + 1;
        int n = 1;  //  n表示桶中記錄數為recordCount1的最大桶數
        m = recordCount1 * n;
        while(((記錄總數 - m)  mod  (桶數 -  n))  != 0 )
        {
            n++;
            m = recordCount1 * n;
        } 
        recordCount2 = (記錄總數 - m) div  (桶數 - n);
        將前n個桶的記錄數設為recordCount1
        將n + 1個至後面所有桶的記錄數設為recordCount2
    }