首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在SQL中获取最新更新记录的要求

在SQL中获取最新更新记录的要求
EN

Stack Overflow用户
提问于 2018-06-07 04:45:43
回答 3查看 46关注 0票数 1

对于下面的数据,我需要用最新的修订来获取记录。在下面给出的数据中,我有两个行,分别是Doc# 5和Item# 048以及修订版0和1。我的要求是拿出所有的记录与最大的修订。@nd示例是doc#17,其中有三个修订版,分别为0、1和2,但要求得到最新的修订版2。

代码语言:javascript
复制
Doc#|   GO#       |    Item#   |Documentationtype  |Revision
1      MNY0005902      064          T-1 DWG            0
2      MNY0005902      59A      Transient Study        0
3      MNY0005902      048      Mimic Panel            0
4      MNY0005902      59A      Transient Study        0
5      MNY0005902      048      Mimic Pane             0
5      MNY0005902      048      Mimic Panel            1
13     MNY0005902      064      T-1 SUB                0
16     MNY0005902      064      T-1 FIO                0
17     MNY0005902      064      T-1 TR                 0
17     MNY0005902      064      T-1 TR                 1
17     MNY0005902      064      T-1 TR                 2

输出应该是

代码语言:javascript
复制
Doc#|   GO#       |    Item#   |Documentationtype  |Revision
1      MNY0005902      064          T-1 DWG            0
2      MNY0005902      59A      Transient Study        0
3      MNY0005902      048      Mimic Panel            0
4      MNY0005902      59A      Transient Study        0
5      MNY0005902      048      Mimic Panel            1
13     MNY0005902      064      T-1 SUB                0
16     MNY0005902      064      T-1 FIO                0
17     MNY0005902      064      T-1 TR                 2
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-06-07 05:04:13

这可以很容易地使用ROW_NUMBER()实现。

代码语言:javascript
复制
SELECT *
FROM
(
    SELECT *, R = ROW_NUMBER() OVER (PARTITION BY Doc#, Item# ORDER BY Revision DESC)
    FROM   yourtable
) as D
WHERE R = 1
票数 1
EN

Stack Overflow用户

发布于 2018-06-07 05:06:39

您可以使用公共表表达式来减少数据,只获得最新的修订,然后在表上选择并在CTE上进行内部连接。

代码语言:javascript
复制
;WITH rows AS
(
  SELECT Doc, MAX(Revision) AS Revision
  FROM TheTable
  GROUP BY Doc
)
SELECT TheTable.Doc, TheTable.GO, TheTable.Item, TheTable.DocumentationType, TheTable.Revision
FROM TheTable
INNER JOIN rows ON TheTable.Doc = rows.Doc AND TheTable.Revision = rows.Revision

在这里工作SQLFiddle,这也应该适用于MSSQL 2008。

票数 1
EN

Stack Overflow用户

发布于 2018-06-07 05:08:03

这个查询应该给出预期的结果。

代码语言:javascript
复制
;WITH CTE as(
select *,row_number()over(partition by doc# order by revision desc) RID
from #docs
)

select doc#,Go#,Item#,DocumentationType,Revision from CTE where RID=1
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50733107

复制
相关文章

相似问题

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