繁体   English   中英

减去上一行以计算 MS SQL 中的列值

[英]Subtract previous row to calculate column value in MS SQL

我有以下数据,需要对其进行格式化以仅显示连续天数而不会中断。

例如,我想显示日期从2018-06-182018-06-21的记录,因为这些是连续的天数。 但是我不想显示日期为2018-06-272018-07-03的行,因为这些日子没有序列。 Friday-Monday例外,会有明显的差距。 例如,如果日期是2018-06-21 (星期四)、 2018-06-22 (星期五)和2018-06-25 (星期一),那么这将是一个有效的序列。

序列2018-6-1 , 2018-6-3 , 2018-6-4必须隐藏,因为它被破坏了(表中没有2018-6-2的记录)。

我在下面写过,但它无法提供我正在寻找的 output。 任何帮助将不胜感激。

select date, diff, Percent_gain, day, month, Year
from (
   select date
      ,datediff(day, '2018-1-29',date) - coalesce(lag(datediff(day, '2018-1-29', date)) over (order by date), 0) as diff
      ,Percent_gain, day, month, year
   from tab
) t1
where t1.diff < 2
   and t1.Percent_gain < 0

在此处输入图像描述

Output

在此处输入图像描述

您可以使用 window 函数和条件表达式:

select *
from (
    select t.*, lag(date) over(order by date) lag_date
    from mytable t
    where percent_gain < 0
) t
where 
    lag_date is null
    or date = dateadd(day, case when datename(dw, date) = 'Monday' then 3 else 1 end, lag_date)

子查询过滤percent_gain为负数的行,并使用lag()检索“上一个”行的date 然后,外部查询再次根据以下条件进行过滤:

  • 任一行是“第一”行(即没有前一个日期)

  • 或当前行的日期比前一个日期晚一天 - 如果当前日期是星期一则除外,在这种情况下,当前日期应比前一个日期晚 3 天

请注意,查询实际上并不使用列daymonthyear 这些看起来像派生值,可以在需要时轻松即时计算。 通常,我们使用datename()来获取日期名称。

您可以使用它作为查找序列的替代方法。

WITH dates(id ,date)
AS
(
 SELECT 1, '2020-03-10'   UNION 
 SELECT 2, '2020-03-15'   UNION
 SELECT 3, '2020-04-17'   UNION
 SELECT 3, '2020-04-20'   UNION
 SELECT 3, '2020-04-21'   UNION
 SELECT 3, '2020-04-22'   UNION
 SELECT 4, '2020-04-25' 
)

Select A.*,CASE WHEN day_name = 'MONDAY'
                THEN CASE WHEN datediff(d,A.prev_date,A.date) = 3
                          THEN 1
                          ELSE 0 END
                ELSE CASE WHEN datediff(d,A.prev_date,A.date) = 1
                          THEN 1
                          ELSE 0 END
                END AS Is_seq

from (Select t.*, DATENAME(dw,date) as day_name,
             lag(date) over (order by date) as prev_date
      from dates t
     ) A

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM