--本周
select trunc(sysdate,'d')+1 from dual
union all
select trunc(sysdate,'d')+7 from dual;
--本月
select trunc(sysdate,'mm') from dual
union all
select last_day(trunc(sysdate)) from dual;
--本季
select trunc(sysdate,'Q') from dual
union all
select add_months(trunc(sysdate,'Q'),3)-1 from dual;
--本年
select trunc(sysdate,'yyyy') from dual
union all
select add_months(trunc(sysdate,'yyyy'),12)-1 from dual;
-- 获取上月的开始时间和结束时间
select to_char(to_date(to_char(add_months(sysdate,-1),'yyyy-mm'),'yyyy-mm'),'yyyy-mm-dd hh24:mi:ss') from dual
union all
select to_char(to_date(to_char(sysdate,'yyyy-mm'),'yyyy-mm'),'yyyy-mm-dd hh24:mi:ss') from dual;
-- 获取前一天的开始时间和结束时间
select to_char(to_date(to_char(sysdate-1,'yyyy-mm-dd'),'yyyy-mm-dd'),'yyyy-mm-dd hh24:mi:ss') from dual
union all
select to_char(to_date(to_char(sysdate,'yyyy-mm-dd'),'yyyy-mm-dd'),'yyyy-mm-dd hh24:mi:ss') from dual;
-- 获取前一小时的开始时间和结束时间
select to_date(to_char(sysdate,'yyyy-mm-dd')||(to_char(to_date(to_char(sysdate,'hh24')-1,'hh24'),'hh24')),'yyyy-mm-dd hh24') from dual
union all
select to_date(to_char(sysdate,'yyyy-mm-dd')||(to_char(sysdate,'hh24')),'yyyy-mm-dd hh24') from dual;
--获取当前时间前一天前一小时前一秒
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual --当前时间
union all
select to_char(sysdate-1-1/24-1/24/60-1/24/60/60 ,'yyyy-mm-dd hh24:mi:ss') from dual;
-- 获取前一年最后一秒
select to_char(to_date(to_char(trunc(sysdate,'yyyy'),'yyyy-mm-dd hh24:mi:ss'),'yyyy-mm-dd hh24:mi:ss')-1/24/60/60,'yyyy-mm-dd hh24:mi:ss') from dual;
--去年第一天最后一天
select add_months(trunc(sysdate,'YYYY'),-12) from dual
union all
select trunc(sysdate,'YYYY')-1 from dual;
--本年第一天到最后一天
select trunc(sysdate,'YYYY') from dual
union all
select add_months(trunc(sysdate,'YYYY'),12)-1 from dual;