本月,上月第一天与最后一天,oracle与sqlserver两种写法
sql server
--本月第一天
select CONVERT(varchar(100), dateadd(d,-day(getdate())+1,getdate()), 23);
--本月最后一天
select CONVERT(varchar(100),dateadd(month, datediff(month, 0, dateadd(month, 1, getdate())), -1), 23);
--上个月最后一天;
CONVERT(varchar(100), DATEADD(MONTH, DATEDIFF(MONTH, -1, GETDATE())-1, -1), 23);
--上个月第一天:
convert(varchar(20),DATEADD(MONTH, DATEDIFF(MONTH, 0, GETDATE())-1, 0),111)
oracle
-- 上月首天
select to_char(add_months(last_day(sysdate)+1,-2),'yyyy-MM-dd') day from dual ;
-- 上月月末
select to_char(last_day(add_months(last_day(sysdate)+1,-2)),'yyyy-MM-dd') day from dual ;
-- 当月首天
select to_char(add_months(last_day(sysdate)+1,-1),'yyyy-MM-dd') day from dual ;
-- 当月月末
select to_char(last_day(add_months(last_day(sysdate)+1,-1)),'yyyy-MM-dd') day from dual ;