解析:怎样将存储过程 重新编写为 函数

本文主要描述了如何确定是否将现有存储过程逻辑重新编写为用户定义函数。例如,如果希望直接从查询唤醒调用存储过程,可将代码重新打包为用户定义函数。

一般来说,如果存储过程返回一个(单个)结果集,则定义表值函数。如果存储过程计算标量值,则定义标量函数。

表值函数的条件

如果存储过程满足以下条件,则可作为重新编写为表值函数的很好的候选存储过程:

逻辑可在单个 SELECT 语句中表现,但它是存储过程而不是视图,只是由于需要参数。可使用内嵌表值函数处理这种情况。

存储过程不执行更新操作(除了对表变量外)。

不需要动态 EXECUTE 语句。

存储过程返回一个结果集。

存储过程的主要目的是生成要装载到临时表的中间结果,SELECT 语句随后将查询临时表。可使用表值函数编写 INSERT...EXEC 语句。例如,请看下面的序列:

INSERT #temp EXEC sp_getresults SELECT ... FROM #temp, t1 WHERE ...

可将存储过程 sp_getresults 重新编写为表值函数,如 fn_results(),这意味着可将上面的语句重新编写为:

SELECT ... FROM fn_results(), t1 WHERE ...

转载于:https://www.cnblogs.com/duanyanfang/archive/2011/10/17/2215560.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值