標量函數,多語句表值函數,內嵌表值函數


標量函數返回一個標量(單值)結果,可返回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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM