--本周
selecttrunc(sysdate,'d')+1fromdual
union all
selecttrunc(sysdate,'d')+7fromdual;
--本月
selecttrunc(sysdate,'mm')fromdual
union all
selectlast_day(trunc(sysdate))fromdual;
--本季
selecttrunc(sysdate,'Q')fromdual
union all
selectadd_months(trunc(sysdate,'Q'),3)-1fromdual;
--本年
selecttrunc(sysdate,'yyyy')fromdual
union all
selectadd_months(trunc(sysdate,'yyyy'),12)-1fromdual;
-- 获取上月的开始时间和结束时间
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;