SQL Server 自定义函数

标量值函数

如果RETUR NS 子句指定一种标量数据类型,则函数为标量值函数

如果RETURNS 子句指定 TABLE,则函数为表值函数
如果RETURNS 子句指定的TABLE 不附带列,则该函数为内嵌表值函数

如果RETURNS 子句指定的TABLE 类型带有列及其数据类型,则该函数是多语句表值函数

标量值函数

返回的结果只是一个标量,返回的结果就是一种类型的一个值


--标量值函数
create function GetSum
(
@num1 int , @num2 int
)
returns int

as

begin 

declare @return int
set @return = @num1 + @num2
return @return

end

select dbo.GetSum(1,3)


内联表值函数

内联表值函数返回的是表数据,它返回的是一个表内表值型函数没有由BEGIN-END语句括起来的函数体


多语句表值函数

多语句表值函数跟内联表值函数都是表值函数,它们返回的结果都是Table类型

多语句表值函数顾名思义,就是可以通过多条语句来创建Table类型的数据。

这里不同于内联表值函数,内联表值函数的返回结果是由函数体内的SELECT语句来决定。

而多语句表值函数,则是需要指定具体的Table类型的结构。也就是说返回的Table,已经定义好要哪些字段返回。所以它能够支持多条语句的执行来创建Table数据。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值