7

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

例如:

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

fn_days 所做的只是返回一个 int 的工作天数。

4

2 回答 2

11

是的,标量会以您编码的方式多次调用。使其工作的一种方法是将其包装到这样的子查询中:

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 每行只被调用一次,而不是像你提到的那样两次或六次。

希望这可以帮助。

于 2012-04-13T00:30:24.857 回答
3

函数是确定性的,这意味着它总是为给定的参数返回相同的值。您使用变量作为参数,因此您可以在执行查询之前调用该函数一次,并在查询中使用结果而不是调用该函数。

DECLARE @Days int
SET @Days = [dbo].[fn_Days](@Account)

SELECT 
  @Days + u.[DayRate],
  @Days / u.[WorkDays]
FROM [dbo].[tblUnit] u  
于 2012-04-13T02:21:23.623 回答