【发布时间】:2017-02-13 20:27:26
【问题描述】:
我有一个名为“Employee”的表
员工表有下面的列
Id (Identity)
EmploymentStartDate (datetime),
EmploymentEndDate (nullable datetime)
T-SQL 查询
DECLARE @FromYear int, @ToYear int
SELECT @FromYear = YEAR(MIN(EmploymentStartDate)),
@ToYear = YEAR(GETDATE())
FROM Employee
;WITH CTE AS
(
SELECT @FromYear As TheYear
UNION ALL
SELECT TheYear + 1
FROM CTE
WHERE TheYear < @ToYear
)
SELECT TheYear as [Year],
COUNT
(
CASE WHEN TheYear <= YEAR(COALESCE(EmploymentEndDate, GETDATE())) THEN
1
END
) As [EmployeeCountPerYear]
FROM CTE
INNER JOIN Employee ON(TheYear >= YEAR(EmploymentStartDate))
GROUP BY TheYear
问题:
Employee 表有以下行数据。
Id - EmploymentStartDate - EmploymentEndDate
1 - '2012-10-10' - null
2 - '2014-10-10' - '2015-10-10'
3 - '2015-10-10' - null
4 - '2016-10-10' - null
5 - '2017-10-10' - null
根据上表行值,我的查询结果应如下所示
TheYear - EmployeeCountPerYear
2012 - 1
2013 - 1
2014 - 2
2015 - 3 (Because EmploymentEndDate has one employee that worked in 2015)
2016 - 3
2017 - 4
但是,如果我运行我的查询,我看不到上面的结果。我不确定我是否能说出问题,但 我正在尝试逐年查找所有员工的工作开始日期和结束日期 .任何帮助将不胜感激。谢谢。
【问题讨论】:
标签: sql sql-server tsql