微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql – 多次调用select语句中的标量函数多次运行该函数,以及如何解决这个问题

如果我在各种计算中使用了带有标量函数的select语句,那么标量函数是否会被多次调用?如果是这样,有没有办法优化它,所以它只调用每个选择一次的函数,因为在我的真实查询中它将被调用数千次,每次选择X 6次.

例如:

SELECT 
[dbo].[fn_Days](@Account) + u.[DayRate],[dbo].[fn_Days](@Account) / u.[WorkDays]
FROM [dbo].[tblUnit] u

所有fn_days都返回一个工作日的int.

解决方法

是的,标量会被编码多次调用.使其工作的一种方法是将其包装到这样的子查询中:
SELECT t.[days] + t.[DayRate],t.[days] / t.[WorkDays]
FROM (
     SELECT 
     [dbo].[fn_Days](@Account) as days,u.[DayRate],u.[WorkDays]
     FROM [dbo].[tblUnit] u) as t

这样fn_Days每行只调用一次,而不是像你提到的那样调用两次或六次.

希望这可以帮助.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐