*获取上月第一天零点时间
--定义变量上月初
declare @BeforeFirstDt datetime;
--获取上月初此时刻
select @BeforeFirstDt=dateadd(dd,-day(dateadd(month,-1,getdate()))+1,dateadd(month,-1,getdate())) ;
--将时间点置为0点时刻
select @BeforeFirstDt= cast(convert(varchar(10),@BeforeFirstDt,120)+' 00:00:00' as datetime)
--显示结果
select @BeforeFirstDt;
*获取上月最后一天时间
--定义变量上月月底
declare @BeforeLastDt datetime;
--获取上月底此时刻
select @BeforeLastDt=dateadd(dd,-day(getdate()),getdate()) ;
--将时间点置为下月凌晨前一秒时刻
select @BeforeLastDt= cast(convert(varchar(10),@BeforeLastDt,120)+' 23:59:59' as datetime)
--显示结果
select @BeforeLastDt;
*获取本月第一天零点时间
--定义变量本月第一天
declare @Dt datetime;
--获取上月底此时刻
select @Dt=dateadd(dd,-day(getdate())+1,getdate()) ;
--将时间点置为下月凌晨前一秒时刻
select @Dt= cast(convert(varchar(10),@Dt,120)+' 00:00:00' as datetime)
--显示结果
select @Dt;
*获取本月最后一天时间
--定义变量本月月底
declare @Dt datetime;
--获取上月底此时刻
select @Dt=dateadd(dd,-day(dateadd(month,1,getdate())),dateadd(month,1,getdate())) ;
--将时间点置为下月凌晨前一秒时刻
select @Dt= cast(convert(varchar(10),@Dt,120)+' 23:59:59' as datetime)
--显示结果
select @Dt;
*获取下月月头
--定义变量下月月头
declare @Dt datetime;
--获取上月底此时刻
select @Dt=dateadd(dd,-day(dateadd(month,1,getdate()))+1,dateadd(month,1,getdate())) ;
--将时间点置为下月凌晨前一秒时刻
select @Dt= cast(convert(varchar(10),@Dt,120)+' 00:00:00' as datetime)
--显示结果
select @Dt;
*获取下月月底
--定义变量下月月底
declare @Dt datetime;
--获取上月底此时刻
select @Dt=dateadd(dd,-day(dateadd(month,2,getdate())),dateadd(month,2,getdate())) ;
--将时间点置为下月凌晨前一秒时刻
select @Dt= cast(convert(varchar(10),@Dt,120)+' 00:00:00' as datetime)
--显示结果
select @Dt;