首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >获取存储数据增量的表的最新记录?

获取存储数据增量的表的最新记录?
EN

Stack Overflow用户
提问于 2012-04-14 07:12:08
回答 2查看 1.3K关注 0票数 0

我有一个表Actions,模式blow:

代码语言:javascript
复制
[Actions]
ActionID
Date
Status <--Nullable, a delta column, only stores value when status changes

现在我想要检索最新的记录,但是该记录的Stutus很可能是null,因此我想得到它的最后一次状态更改(按Date排序)。

下面是一个示例:

代码语言:javascript
复制
ActionID | Date | Status
------------------------
1        | 04/12| 'Bon'
2        | 04/13| NULL
3        | 04/14| NULL
4        | 04/15| NULL

我的最新记录应该是这样的:ActionID: 4Date: 04/15Status: 'Bon'

我知道可以使用嵌套的select语句,但在我的实际表中,我有大约10个这样的列,当进行大量这样的查询时,这将极大地影响性能。我想知道有没有更简单的方法?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-04-14 07:29:04

不知道我是否理解了你的规则,但是试试这个:

代码语言:javascript
复制
SELECT TOP 1
ActionID,
Date,
(SELECT TOP 1 Status FROM Actions WHERE Status IS NOT NULL ORDER BY ActionID DESC) AS Status
FROM Actions
ORDER BY ActionID DESC

你说你有10列..它是如何工作的?

如场景A)

代码语言:javascript
复制
 ActionID | Date  | StatusA | StatusB | StatusC
        1 | 04/11 | DELTA_A | NULL    | DELTA_C
        2 | 04/12 | NULL    | DELTA_B | DELTA_C
        3 | 04/13 | DELTA_A | NULL    | NULL 

我认为..then多个SELECT TOP1子查询仍然是最佳选择。

但如果它类似于场景B)

代码语言:javascript
复制
 ActionID | Date  | StatusA | StatusB | StatusC
        1 | 04/11 | NULL    | NULL    | NULL
        2 | 04/12 | DELTA_A | DELTA_B | DELTA_C
        3 | 04/13 | NULL    | NULL    | NULL 

..then您可以像这样“反转”您的查询:

代码语言:javascript
复制
SELECT TOP 1
(SELECT TOP 1 ActionID FROM Actions WHERE Status IS NOT NULL ORDER BY ActionID DESC) AS ActionID,
(SELECT TOP 1 Date FROM Actions WHERE Status IS NOT NULL ORDER BY ActionID DESC) AS Date,
StatusA,
StatusB,
StatusC
FROM Actions
WHERE StatusA IS NOT NULL -- then StatusB and StatusC are also NOT NULL
ORDER BY ActionID DESC

..but请注意,如果没有StatusA = NOT NULL的行,则可能会得到空结果。

票数 0
EN

Stack Overflow用户

发布于 2012-04-14 07:41:44

也许这对你有帮助,尽管我不确定我是否理解了你的需求:

代码语言:javascript
复制
WITH Actions AS(
   SELECT ROW_NUMBER()OVER(Order By Date DESC)AS DateRank
        , ActionsID
        , Date
        , Status
    FROM [Actions]
)
SELECT TOP 1 a1.ActionsID,a1.Date,a2.Status 
FROM Actions a1 INNER JOIN Actions a2 
    ON a1.DateRank < a2.DateRank AND a2.Status IS NOT NULL
WHERE a1.DateRank=1
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10149432

复制
相关文章

相似问题

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