使用 cte 循环的每日快照 table

Daily snapshot table using cte loop

我需要在任何一天(定义为 Start_Date 和 End_Date 之间的@date)雇用多少员工的每日快照,每个日期一行。

在某一时刻,以下脚本会 return 所有每日快照,但它们每个都 return 在单独的结果 window 中编辑。我无法获得合并所有结果以将每个新结果插入 #PLEASEWORK 的查询。

我需要让下面的内容连续工作两天。它使用 int 日期。我继承了这个问题,正在建立一个日期 table 来解决这个问题。

CREATE TABLE #PLEASEWORK
(
    [Date] INT
    ,Division_Description VARCHAR (100)
    ,[Count] INT
)

DECLARE @cnt AS INT
DECLARE @DATE AS INT

SET @CNT = '20181001'

WHILE @cnt >= @DATE

BEGIN

SELECT @DATE = '20181031' - 1


TRUNCATE TABLE #PLEASEWORK
INSERT INTO #PLEASEWORK

SELECT
    @DATE [date]
    ,Division_Description
    ,COUNT(*) [Count]
--INTO #PLEASEWORK
FROM EmpMaster

WHERE
    ([Start_Date] <= @DATE
    AND Leaving_Date = 0)
    OR ([Start_Date] <= @DATE
    AND Leaving_Date > @DATE)

GROUP BY
    Division_Description


SET @cnt = @cnt + 1

CONTINUE


SELECT *

FROM #PLEASEWORK

END

您可以在一个查询中完成所有这些。这是一种方法(不是最有效的),但一个月应该没问题。

declare @DATESTART date = '20181001';
declare @DATEEND date = '20181031';

with dates as (
      select @DATESTART as dte
      union all
      select dateadd(day, 1, dte)
      from dates
      where dte < @DATEEND
     )
select d.dte, dd.Division_Description,
       (select count(*)
        from EmpMaster e
        where e.Division_Description = dd.Division_Description and
              e.start_date <= d.dte and
              (e.leaving_date >= d.dte or e.leaving_date is null)
       ) as num_employees
from dates d cross join
     (select distinct Division_Description from EmpMaster) dd
order by d.dte, dd.Division_Description;

有了 EmpMaster(Division_Description, start_date, leaving_date) 上的索引,这应该比基于游标的方法好得多。