sql – 多次调用select语句中的标量函数多次运行该函数,以及如何
发布时间:2020-12-12 08:53:27 所属栏目:MsSql教程 来源:网络整理
导读:如果我在各种计算中使用了带有标量函数的select语句,那么标量函数是否会被多次调用?如果是这样,有没有办法优化它,所以它只调用每个选择一次的函数,因为在我的真实查询中它将被调用数千次,每次选择X 6次. 例如: SELECT [dbo].[fn_Days](@Account) + u.[DayRa
如果我在各种计算中使用了带有标量函数的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每行只调用一次,而不是像你提到的那样调用两次或六次. 希望这可以帮助. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |