首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >条件划分

条件划分
EN

Stack Overflow用户
提问于 2014-12-05 16:09:14
回答 1查看 1.1K关注 0票数 1

我有一个表(Employee_Training),它有以下列:

  • Employee_Number
  • Course_ID
  • Date_Completed

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

代码语言:javascript
复制
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的所有行。

以下是一些示例数据:

只需在该表上使用select all:

代码语言:javascript
复制
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

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

代码语言:javascript
复制
557 | 1000002 | 2014-11-18
557 | 1000004 | 2011-1-15
557 | 1000010 | 2014-6-10

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

代码语言:javascript
复制
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

谢谢。

谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-12-05 16:23:23

您可以将它们排除在row_number分区之外,并在最后将它们合并。

代码语言:javascript
复制
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
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27320064

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档