条件分区

时间:2014-12-05 16:09:14

标签: sql sql-server tsql

我有一个表(Employee_Training),其中包含以下列:

  • Employee_Number
  • Course_ID
  • Date_Completed

我有这个用于显示培训的查询,它会过滤掉重复的Date_Completed,只显示最近的日期:

SELECT x.*
FROM (SELECT t.*, ROW_NUMBER() OVER 
    (PARTITION BY t.Course_ID, t.Employee_Number 
            ORDER BY t.Date_Completed DESC) AS rank
        FROM Employee_Training t) x
WHERE x.rank = 1

有没有办法格式化这个查询而不是将分区应用到特定的Course_ID,比如1000004?我想查看Course_ID = 1000004的所有行。

以下是一些示例数据:

只需在该表上使用全选:

557 | 1000002 | 2014-11-18
557 | 1000002 | 2009-7-6
557 | 1000004 | 2011-1-15
557 | 1000004 | 2005-9-22
557 | 1000004 | 2004-4-17
557 | 1000010 | 2014-6-10
557 | 1000010 | 2013-6-09
557 | 1000010 | 2012-6-10

使用原始查询我得到以下结果:

557 | 1000002 | 2014-11-18
557 | 1000004 | 2011-1-15
557 | 1000010 | 2014-6-10

我想看到的内容(只有1000004没有被过滤掉):

557 | 1000002 | 2014-11-18
557 | 1000004 | 2011-1-15
557 | 1000004 | 2005-9-22
557 | 1000004 | 2004-4-17
557 | 1000010 | 2014-6-10

谢谢。

谢谢。

1 个答案:

答案 0 :(得分:0)

你可以将它们从你的row_number分区中排除,然后将它们联合起来。

SELECT x.*
FROM (SELECT t.*, ROW_NUMBER() OVER 
    (PARTITION BY t.Course_ID, t.Employee_Number 
            ORDER BY t.Date_Completed DESC) AS rank
        FROM Employee_Training t
       WHERE course_id!=1000004) x
WHERE x.rank = 1

UNION ALL

SELECT t.*,1 as rank
        FROM Employee_Training t
        WHERE course_id=1000004