一、函數
說到函數,首先和存儲過程作個比較吧,兩者有一個共同點都是預編譯優化後存儲在磁盤中,所以效率
要比T-SQL高一點點。值得注意的是,存儲過程可以創建或訪問臨時表,而函數不可以;同時函數不可
以修改表中的數據,或調用產生副作用的函數,比如rand,newid,getdate(當然這並不是絕對的);但
是函數可以作爲select 或from或where子句的一部分,而存儲過程不可以。
二、函數有哪些?
1 字符串函數
1.1 長度與分析用
datalength(Char_expr) 返回字符串包含字符數,但不包含後面的空格 substring(expression,start,length) 不多說了,取子串 right(char_expr,int_expr) 返回字符串右邊int_expr個字符 left(char_expr,int_expr) 返回字符串左邊int_expr個字符
1.2 字符操作類
upper(char_expr) 轉爲大寫 lower(char_expr) 轉爲小寫 space(int_expr) 生成int_expr個空格 replicate(char_expr,int_expr)複製字符串int_expr次 reverse(char_expr) 反轉字符串 stuff(char_expr1,start,length,char_expr2) 將字符串char_expr1中的從 start開始的length個字符用char_expr2代替 ltrim(char_expr) rtrim(char_expr) 取掉空格 ascii(char) char(ascii) 兩函數對應,取ascii碼,根據ascii碼取字符
1.3 字符串查找
charindex(char_expr,expression) 返回char_expr的起始位置 patindex("%pattern%",expression) 返回指定模式的起始位置,否則爲0
2、數學函數
abs(numeric_expr) 求絕對值。 ceiling(numeric_expr) 取大於等於指定值的最小整數(即向上取整)。 floor(numeric_expr) 小於等於指定值得最大整數(即向下取整)。 avg(numeric_expr)取平均數。 exp(float_expr) 返回e的n次方。 pi() 3.1415926.........(即圓周率π)。 power(底數m,指數n) 返回m的n次方。 rand([int_expr]) 隨機數產生器。 round(numeric_expr,int_expr) 按照int_expr規定的精度四捨五入。 sign(int_expr) 根據正數,零,負數,返回+1,0,-1。 sqrt(float_expr) 返回平方根。
3、日期時間函數
getdate() 返回日期 datename(datepart,date_expr) 返回名稱如 June datepart(datepart,date_expr) 取日期一部份 datediff(datepart,date_expr1.dateexpr2) 日期差 dateadd(datepart,number,date_expr) 返回日期加上 number 上述函數中datepart的 寫法 取值和意義 yy 1753-9999 年份 qq 1-4 刻 mm 1-12 月 dy 1-366 日 dd 1-31 日 wk 1-54 周 dw 1-7 周幾 hh 0-23 小時 mi 0-59 分鐘 ss 0-59 秒 ms 0-999 毫秒 日期轉換 convert()
4、系統其他函數
suser_name() 用戶登錄名 user_name() 用戶在數據庫中的名字 show_role() 對當前用戶起作用的規則 db_name() 數據庫名 object_name(obj_id) 數據庫對象名 col_name(obj_id,col_id) 列名 col_length(objname,colname) 列長度 valid_name(char_expr) 是否是有效標識符
5、類型轉換函數
convert (數據類型[(長度)],表達式[,樣式]) 將一種數據類型的表達式顯式轉換爲另一種數據類型的表達式; 長度:如果數據類型允許設置長度,可以設置長度,例如 varchar(10); 樣式:用於將日期類型數據轉換爲字符數據類型的日期格式的樣式。 cast (表達式 AS 數據類型[(長度)]) 將一種數據類型的表達式顯式轉換爲另一種數據類型的表達式。 例如:select cast(123 as nvarchar) 返回123 select N'年齡:' + cast(23 as nvarchar) 返回 年齡:23
6、系統函數
newid 無參數 返回一個GUID(全局唯一表示符)值 例如:select newid() 返回:2E6861EF-F4DB-4FFE-86EB-637482FE982J2 isnumeric (任意表達式) 判斷表達式是否爲數值類型或者是否可以轉換成數值。 是:返回1,不是:返回0 例如:select isnumeric(1111) 返回 1 select isnumeric('123rr') 返回 0 select isnumeric('123') 返回 1 isnull (任意表達式1,任意表達式2) 如果任意表達式1不爲NULL,則返回它的值;否則,在將任意表達式2的類型轉換爲任意表達式1的類型(如果這兩個類 型不同)後,返回任意表達式2的值。 例如:select isnull(null,N'沒有值') 返回 沒有值 select isnull(N'具體的值',N'沒有值') 返回 具體的值 isdate (任意表達式) 確定輸入表達式是否爲有效日期或可轉成有效的日期; 是:返回1,不是:返回0 例如:select isdate(getdate()) 返回1 select isdate('2013-01-02') 返回1 select isdate('198') 返回0
7、排名函數
row_number 無參數 爲結果集內每一行進行編號,從1開始後面行依次加1,常用於產生序號; 例如:select row_number() over(order by userid desc) as [NO],username,password from T_USER
8、聚合函數
count() 返回組中的總條數,count(*)返回組中所有條數,包括NULL值和重複值項,如果抒寫表達式,則忽略空值,表達式爲 任意表達式。 max() 返回組中的最大值,空值將被忽略,表達式爲數值表達式,字符串表達式,日期。 min() 返回組中的最小值,空值將被忽略,表達式爲數值表達式,字符串表達式,日期。 sum() 返回組中所有值的和,空值將被忽略,表達式爲數據表達式。 avg() 返回組中所有值的平均值,空值將被忽略,表達式爲數據表達式
表值函數:返回一張表,比如returns table as ... return select ....
標量值函數:返回當個數據類型的值(除BLOB、遊標、時間戳),比如returns int as ... return
@var;