【问题标题】:How can I extract last years data based on today's date如何根据今天的日期提取去年的数据
【发布时间】:2018-01-08 17:20:30
【问题描述】:

我想提取 2016 年的所有数据,通常我会使用:

date > DATEADD(year, -1, GETDATE())

但是当我在 2018 年 1 月运行报告时,我仍然希望它显示 2016 年的数据,当我在 2 月 18 日再次运行它时,它开始显示 2017 年的所有数据。

【问题讨论】:

  • “去年”不是 2016 年...改用参数。
  • 具体了解您要查询的数据“窗口”是什么。以及何时应该发生 transition。 IE。是不是应该在 1 月 31 日 11:55 看到 [2016-01-01 - 2017-01-01) 的数据,而在 2 月 1 日 00:05 看到 [2017-01-01 - 2018-01-01) 的数据?其他月份呢?

标签: sql sql-server date where


【解决方案1】:

你可以得到-2年
2018 - 2 = 2016

date > DATEADD(year,-2,GETDATE())

【讨论】:

  • 不幸的是,这不起作用,因为整个 2018 年只会显示 2016 年,我希望它自动更改为仅从 2018 年 2 月 1 日到 2019 年 1 月 31 日显示整个 2017 年。我不不想每年都在改变它。
【解决方案2】:

减去Month 而不是Year,如下所示:

DATEADD(month, -13, GETDATE())

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2019-10-19
    • 2017-06-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-12-01
    • 2020-05-10
    • 2020-05-12
    相关资源
    最近更新 更多