首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >计数日SQL Server

计数日SQL Server
EN

Stack Overflow用户
提问于 2016-11-14 13:16:07
回答 2查看 57关注 0票数 0

我目前正试图解决我的一个问题。

代码语言:javascript
复制
   | ID | Op | Object | STATE | Timestamp |
   | 01 | 1  | A      |   1   | 01-02-2016|
   | 02 | 1  | A      |   2   | 04-02-2016|
   | 03 | 1  | A      |   1   | 10-02-2016|
   | 04 | 1  | A      |   3   | 01-02-2016|
   | 05 | 2  | A      |   2   | 02-02-2016|
   | 06 | 3  | A      |   1   | 05-02-2016|
   | 07 | 3  | A      |   2   | 10-11-2016|

我需要写一个SQL,返回一个对象在状态2通过的天数。例如,对象A,停留在状态2+ 02-02到05-02,以及从10-11到今天6天+3天+4天。

代码语言:javascript
复制
  SQL return 13

目前使用的是代码,但我需要在SQL解压缩中使用它,我不知道如何继续。SQL有可能做到这一点吗?

谢谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-11-14 13:18:57

我认为您需要lead()以及聚合和日期逻辑:

代码语言:javascript
复制
select object,
       sum(case when state = 2 then datediff(day, timestamp, coalesce(next_timestamp, getdate()) )
                else 0
           end) as days_state_2
from (select t.*,
             lead(timestamp) over (partition by object order by timestamp) as next_timestamp
      from t
     ) t
group by object;

或者,您可以将筛选条件移动到外部select

代码语言:javascript
复制
select object,
       sum(datediff(day, timestamp, coalesce(next_timestamp, getdate()) )) as days_state_2
from (select t.*,
             lead(timestamp) over (partition by object order by timestamp) as next_timestamp
      from t
     ) t
where state = 2
group by object;
票数 1
EN

Stack Overflow用户

发布于 2016-11-14 13:21:36

代码语言:javascript
复制
select object,
       sum(datediff(day, timestamp, coalesce(next_timestamp, getdate()) )) as days_state_2
from (select *,
             lead(timestamp) over (partition by object order by timestamp) as next_timestamp
      from #b
     ) t
where state = 2
group by object;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40589663

复制
相关文章

相似问题

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