首頁 >資料庫 >mysql教程 >计算给定日期所在月的上月最后一天 sql语句

计算给定日期所在月的上月最后一天 sql语句

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原創
2016-06-07 17:47:242188瀏覽

计算给定日期所在月的上月最后一天 sql语句

计算给定日期所在月的上月最后一天 sql语句

declare @date  datetime
set @date=getdate()
--当前月第一天减去一天
select dateadd(day,-1,dateadd(month,datediff(month,0,@date),0)) as '上月最后一天'
--另一种当前月第一天算法
select dateadd(day,-1,dateadd(day,1-datepart(day,@date),@date)) '上月最后一天'
select dateadd(day,1-datepart(day,@date),@date)-1 '上月最后一天'
--另一种算法,不能用当前月的最后一天加一个月,因为当前月可能是30天。
--例如 select dateadd(month,1,'2010-06-30') --结果是2010-07-30而不是2010-07-31,
--这也是月末算法采用下月第一天减1天计算的原因
--但是如果计算月是31天择无此问题
--例如 select dateadd(month,1,'2010-05-31') --结果是2010-06-30
--因此下面算法是正确的,-1 表示'1899-12-31 00:00:00.000'-- select convert(datetime,-1)
select dateadd(month,datediff(month,-1,@date)-1,-1)
--另一种当前月算法
select dateadd(day,-1,dateadd(day,1-datepart(day,@date),@date)) '上月最后一天'
--简化
select dateadd(day,0-datepart(day,@date),@date) '上月最后一天'
go

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn