具有 CTE 的标量函数失败

zia*_*our 4 sql t-sql sql-server common-table-expression

该函数返回的是单个浮点值,但它始终为空。为什么?


计算每个员工总工作时间的函数:

ALTER FUNCTION GetTotalWorkingHour 
(
    @StartDate datetime, 
    @EndDate datetime, 
    @EmpID nvarchar(6) = null
)
RETURNS float
AS
BEGIN

    DECLARE @Result float;
WITH
CTE_Start
AS
(
    SELECT  EmpID ,SUM(DATEDIFF(minute, (CAST(att.[date] AS datetime) + att.[Time]), @StartDate) *  
    CASE WHEN Funckey = 'EMPIN' THEN +1 ELSE -1 END) AS SumStart
    FROM PERS_Attendance AS att
    WHERE (EmpID = @EmpID OR @EmpID IS NULL) AND att.[date] < @StartDate GROUP BY EmpID
)
,CTE_End
AS
(
    SELECT EmpID ,SUM(DATEDIFF(minute, (CAST(att.[date] AS datetime) + att.[Time]), @EndDate) *  CASE WHEN Funckey = 'EMPIN' THEN +1 ELSE -1 END) AS SumEnd
    FROM  PERS_Attendance AS att
    WHERE (EmpID = @EmpID OR @EmpID IS NULL) AND att.[date] < @EndDate GROUP BY EmpID
)

SELECT @Result = 
    (CTE_Start.SumStart - ISNULL(CTE_End.SumEND, 0) / 60.0) --AS SumHours
FROM
        CTE_End
    LEFT JOIN CTE_Start ON CTE_Start.EmpID = CTE_End.EmpID
RETURN @Result

END
GO
Run Code Online (Sandbox Code Playgroud)

上面的代码以正确的方式运行,如果我在单个查询中使用它(而不是在函数中),它会给出预期的结果,那么有什么问题呢?

zia*_*our 6

我找到了解决方案,这是一个小错误,我必须补充:

SELECT @Result = 
    (SumEnd - ISNULL(SumStart, 0)) / 60.0 --AS SumHours
FROM
        CTE_End
    LEFT JOIN CTE_Start ON CTE_Start.EmpID = CTE_End.EmpID
RETURN @Result
Run Code Online (Sandbox Code Playgroud)

代替:

SELECT @Result = 
    (CTE_Start.SumStart - ISNULL(CTE_End.SumEND, 0) / 60.0) --AS SumHours
FROM
        CTE_End
    LEFT JOIN CTE_Start ON CTE_Start.EmpID = CTE_End.EmpID
RETURN @Result
Run Code Online (Sandbox Code Playgroud)