如果我在各种计算中使用了带有标量
函数的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每行只调用一次,而不是像你提到的那样调用两次或六次.
希望这可以帮助.
原文链接:https://www.f2er.com/mssql/74999.html