亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

SQL Server自定義函數

系統 2148 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條評論
主站蜘蛛池模板: 国产精品1 | 性生活视频网站 | 曰批免费视频播放在线看片 | 国产乱码在线精品可播放 | www.婷婷| 日本吻胸抓胸激烈视频网站 | 日本在线一区二区 | 精品免费久久久久久成人影院 | 性生生活三级视频观看 | 久久婷婷国产综合精品 | 久色阁| 亚洲香蕉在线视频 | 全部免费毛片免费播放 | 欧美综合另类 | 黄网站www| 亚洲区 欧美区 | 欧美 亚洲 一区 | 久久精品国产亚洲高清 | 久久国产精品一区 | 亚洲情区| 黄色小视频免费看 | 亚洲精品www久久久久久久软件 | 国内精品久久久久影院中国 | 四虎影院免费视频 | 国产高清国内精品福利色噜噜 | 伊人75| 久草免费色站 | 欧美国产日产精品免费视频 | 成人亚洲视频在线观看 | 日韩欧美h| 国产成人精品亚洲日本在线 | 亚洲一区二区三区在线网站 | 在线成人毛片 | 久久99精品亚洲热综合 | 久久两性 | 亚洲va天堂va欧美ⅴa | 日本一级高清不卡视频在线 | 欧美区日韩区 | 国产精品久久在线观看 | 国产欧美一区二区三区精品 | 一级一级一级毛片 |