日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

SQL Server自定義函數

系統 2106 0

自定義函數

用戶定義自定義函數像內置函數一樣返回標量值,也可以將結果集用表格變量返回

用戶自定義函數的類型:

標量函數: 返回一個標量值

表格值函數{ 內聯表格值函數、多表格值函數}: 返回行集(即返回多個值)

1 、標量函數

Create function 函數名(參數)

Returns 返回值數據類型

[with {Encryption | Schemabinding }]

[as]

begin

SQL 語句( 必須有return 變量或值)

End

Schemabinding : 將函數綁定到它引用的對象上(注:函數一旦綁定,則不能刪除、修改,除非刪除綁定)

Create function AvgResult(@scode varchar(10))

Returns real

As

Begin

?? Declare @avg real

?? Declare @code varchar(11)

?? Set @code=@scode + ‘%’

?? Select @avg=avg(result) from LearnResult_baijiali

Where scode like @code

Return @avg

End

執行用戶自定義函數

select 用戶名。函數名 as 字段別名

select dbo.AvgResult(‘s0002’) as result

用戶自定義函數返回值可放到局部變量中,用set ,select,exec 賦值

declare @avg1 real ,@avg2 real ,@avg3 real

select @avg1= dbo.AvgResult(‘s0002’)

set @avg2= dbo.AvgResult(‘s0002’)

exec @avg3= dbo.AvgResult ‘s0002’

select @avg1 as avg1 ,@avg2 as avg2 ,@avg3 as avg3

函數引用

create function code(@scode varchar(10))

returns varchar(10)

as

begin

declare @ccode varchar(10)

set @scode = @scode + ‘%’

select @ccode=ccode from cmessage

?? where ccode like @scode

return @ccode

end

select name from class where ccode = dbo.code(‘c001’)

2 、表格值函數

a、 內聯表格值函數

格式:

create function 函數名(參數)

returns table

[with {Encryption | Schemabinding }]

as

return( 一條SQL 語句)

create function tabcmess(@code varchar(10))

returns table

as

return(select ccode,scode from cmessage where ccode like @ccode)

b、 多句表格值函數

?? create function 函數名(參數)

?? returns 表格變量名table ( 表格變量定義)

?? [with {Encryption | Schemabinding }]

as

?? begin

??? SQL 語句

?? end

多句表格值函數包含多條SQL 語句,至少有一條在表格變量中填上數據值

表格變量格式

returns @ 變量名 table (column 定義| 約束定義 [,…])

對表格變量中的行可執行select,insert,update,delete 但select into 和 insert 語句的結果集是從存儲過程插入。

Create function tabcmessalot (@code varchar(10))

Returns @ctable table(code varchar(10) null,cname varchar(100) null)

As

Begin

Insert @ctable

Select ccode,explain from cmessage

Where scode like @code

return

End

Select * from tabcmessalot(‘s0003’)

將存儲過程轉變成函數 ,參閱聯機幫助

?

轉自 http://hi.baidu.com/datachina/blog/item/801def0366c4e7ea09fa9344.html

SQL Server自定義函數


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 乌海市| 乌拉特后旗| 芮城县| 军事| 安顺市| 尚义县| 衡南县| 子洲县| 青海省| 大新县| 临沂市| 依安县| 安阳市| 台东县| 全南县| 阜康市| 泰安市| 镇原县| 定远县| 万荣县| 漳平市| 曲麻莱县| 漳浦县| 永丰县| 和平县| 和顺县| 方城县| 宣城市| 临朐县| 崇礼县| 怀安县| 南和县| 长白| 姚安县| 简阳市| 孝昌县| 河北省| 新竹县| 万年县| 都江堰市| 河间市|