如何从上一个9月获得9月1日?

时间:2019-03-07 16:34:09

标签: sql date sql-server-2014

如果我想选择一个相对于今天的日期,我可以做类似的事情:

DateAdd(month, -2, N'1-Jan-2019')

这将给我2018年11月1日。

如何获取上一年的9月1日呢?

E.G

说是2019年7月, 我想要2018年9月1日,而不是2019年。

但是,

说是2019年11月, 我想要2019年9月1日,而不是2018年。

这怎么可能?

1 个答案:

答案 0 :(得分:3)

您可以通过从date值中减去8个月,然后使用所得的year来确定9月的日期来完成此操作:

declare @d table(d date);
insert into @d values ('20170101'),('20180101'),('20181101'),('20190101'),('20191001'),('20190901'),('20190921'),('20190808');

select d
      ,datefromparts(year(dateadd(month,-8,d)),9,1) as PrevSeptDate
      ,datetimefromparts(year(dateadd(month,-8,d)),9,1,0,0,0,0) as PrevSeptDateTime
from @d
order by d;

输出

+------------+--------------+-------------------------+
|     d      | PrevSeptDate |    PrevSeptDateTime     |
+------------+--------------+-------------------------+
| 2017-01-01 | 2016-09-01   | 2016-09-01 00:00:00.000 |
| 2018-01-01 | 2017-09-01   | 2017-09-01 00:00:00.000 |
| 2018-11-01 | 2018-09-01   | 2018-09-01 00:00:00.000 |
| 2019-01-01 | 2018-09-01   | 2018-09-01 00:00:00.000 |
| 2019-08-08 | 2018-09-01   | 2018-09-01 00:00:00.000 |
| 2019-09-01 | 2019-09-01   | 2019-09-01 00:00:00.000 |
| 2019-09-21 | 2019-09-01   | 2019-09-01 00:00:00.000 |
| 2019-10-01 | 2019-09-01   | 2019-09-01 00:00:00.000 |
+------------+--------------+-------------------------+