oracle运用(八) oracle中的日期查询二

来源:互联网 发布:nginx sticky 编辑:程序博客网 时间:2024/06/06 19:50

一、取得当天0时0分0秒

select TRUNC(SYSDATE) FROM dual;

二、取得当天23时59分59秒(在当天0时0分0秒的基础上加1天后再减1秒)

SELECT TRUNC(SYSDATE)+1-1/86400 FROM dual;

三、取得当天23时59分59秒(在当天0时0分0秒的基础上加1天后再减1秒)

select to_char(sysdate,'D'),to_char(sysdate,'DAY') from dual;

四、取得到当天月份的第一天和最后一天

select to_char(sysdate,'yyyy-mm')||'-01' firstday,to_char(last_day(sysdate),'yyyy-mm-dd') lastday from dual;

五、取得实现当天16点前数据减去昨天16点的,过了16点减去今天16点

select field1, field2 from mytablewhere time = decode(sign(sysdate-trunc(sysdate)-16/24), --时间判断                    -1,trunc(sysdate)-1+16/24, --小于16点取昨天16点                       trunc(sysdate)+16/24)  --大于16点取当天16点






0 0
原创粉丝点击