使用 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)
上的索引,这应该比基于游标的方法好得多。
我需要在任何一天(定义为 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)
上的索引,这应该比基于游标的方法好得多。