标量函数,多语句表值函数,内嵌表值函数
標量函數返回一個標量(單值)結果,可返回Timestamp,text,Ntext,Image,Table,Cursor
多語句表值函數,返回一條或多條Transact-sql語句建立的表,可在select 語句的FROM子句中被引用.
內嵌表值函數,位于RETURN子句中的SELECT命令段從數據庫中摔選出來的,類似于視圖但強于視圖.
標量函數,在Begin...End 之間函數體,不能包非確定性系統函數.
Create Function [own_name.]function_name([{@參數名[as] 數據類型[=默認值]}[,...n]])
Returns 返回數據類型 [With <函數選項>] [As] Begin 函數體 Return 返回表達式 End
調用函數 Select Own_name.function_name[(參數值[,...n])]
多語句表值函數
Begin...End 限定了函數體,Returns指定Table作為返回的數據類型
Create Function[own)name.]function_name([{@參數名[as]數據類型[=默認值]},[,...n]])
Returns @返回變量 Table<表定義>[With<函數選項>][As] Begin 函數體 Return End
調用函數 Select * from own_name.function_name[(參數值[,...n])][where <條件>]
內嵌表值函數
Returns 子句在括號中包含單個Select語句,Returns指定table作為返回的數據類型
不必定義返回變量的格式,因為它由Return子句中的Select語句的結果集格式設置
更改函數 :Alter Function 刪除函數:Drop Function
創 架構綁定函數
創建時用 SchemaBinding 則數據庫對象不能更改(使用Alter 或 Drop語句)
但使用SchemaBinding必須具有對函數中引用對象的Reference權限
mssql二進制加解密, cast(@password as binary(20)) ,cast(@EPassword as varchar(20))
insert into AppUsers(UserName,password) values('tom',dbo.fn_EncryptPassword('00001'))
select username,dbo.fn_DecryptPassWord(password) from AppUsers
Create Function dbo.fn_EncryPassword(@Password varchar(20))
returns binary(20)
begin
???? declare @EPassword binary(20)
???? set @EPassword = cast(@Password as binary(20))
???? return @ EPassword
end
Create Function dbo.fn_DecryptPassword(@EPassword binary(20))
returns varchar(20)
begin
???? declare @Password varchar(20)
???? set @Password = cast(@EPassword as varchar(20))
???? return @Password
end
?
感謝:jude_liu
轉載于:https://www.cnblogs.com/xred/archive/2012/06/09/2542909.html
總結
以上是生活随笔為你收集整理的标量函数,多语句表值函数,内嵌表值函数的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Asp.net报表制作 OpenFlas
- 下一篇: Keil 文本对不上格