sql实用功能片段

*获取上月第一天零点时间

--定义变量上月初
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;

 

转载于:https://my.oschina.net/RabbitXiao/blog/856187

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值