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

SQL Server ——函數種類<>

系統 2247 0

1、函數的種類

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

內嵌表函數:返回一個表,多行多列,只能寫Select語句

多語句函數:是一種受限的T_SQL ,可以寫 while if語句。受限表現在:在增刪改方面:只能對返回的表進行增刪改,不能對別的表進行增刪改。

For example 1:

create function fn_age (@ageadd int)
returns int
as
begin
declare @age int
declare @ageresult int

set @age=@ageadd+1
select @ageresult=avg(age) from lucy where age like @age
return @ageresult
end

//執行,看一下結果
select dbo.fn_age(20) as result(指明列名)

For example2:

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’)

?ref: http://blog.sina.com.cn/s/blog_614316190100etjp.html

SQL Server ——函數種類<>


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 墨江| 常德市| 临泉县| 金平| 莆田市| 英德市| 武胜县| 辉南县| 和龙市| 嘉禾县| 巴林左旗| 葵青区| 沂水县| 西盟| 岳阳县| 晋中市| 揭西县| 金堂县| 巴彦淖尔市| 南丹县| 台南市| 龙游县| 广丰县| 通海县| 麟游县| 义乌市| 额尔古纳市| 开阳县| 亚东县| 甘肃省| 万盛区| 京山县| 隆子县| 藁城市| 永登县| 万安县| 浮山县| 北流市| 根河市| 伊宁县| 鹿邑县|