大家好,我是考100分的小小码 ,祝大家学习进步,加薪顺利呀。今天说一说oracle日期处理「终于解决」,希望您对编程的造诣更进一步.
oracle日期处理
Oracle时间
SELECT SYSDATE FROM dual; -- 系统时间
SELECT SYSTIMESTAMP FROM dual; -- 当前系统时间戳
SELECT CURRENT_TIMESTAMP FROM dual; -- 与时区设置有关,返回的秒是系统的,返回的日期和时间是根据时区转换过的
SELECT current_date FROM dual; -- 是对CURRENT_TIMESTAMP准确到秒的四舍五入
select SYSDATE ,systimestamp,current_date,current_timestamp from dual;
代码100分
时间差计算
代码100分DECLARE
START_DATE DATE;
END_DATE DATE;
BEGIN
START_DATE := SYSDATE - 1 ;
END_DATE := SYSDATE ;
dbms_output.put_line("相差天数 :" || ROUND(TO_NUMBER(END_DATE - START_DATE)));
dbms_output.put_line("相差小时数 :" || ROUND(TO_NUMBER(END_DATE - START_DATE) * 24));
dbms_output.put_line("相差分钟数 :" || ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60));
dbms_output.put_line("相差秒数 :" || ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60));
dbms_output.put_line("相差毫秒数 :" || ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60 * 1000));
END;
字符串转时间类型
to_date()将字符串转换为具体指定的时间日期格式
SELECT to_date("2018-08-23 00:00:00","yyyy-mm-dd hh24:mi:ss") FROM dual;
时间类型转字符串
to_char()将时间日期按照指定的格式输出,得到的是字符串,而非date类型
代码100分select to_char(sysdate,"yyyy-mm-dd hh24::mi:ss") from dual;
select to_char(sysdate,"yyyy-mm-dd") from dual;
时间日期加减
select sysdate,add_months(sysdate,12) from dual; --加1年
select sysdate,add_months(sysdate,1) from dual; --加1月
select sysdate,to_char(sysdate+7,"yyyy-mm-dd HH24:MI:SS") from dual; --加1星期
select sysdate,to_char(sysdate+1,"yyyy-mm-dd HH24:MI:SS") from dual; --加1天
select sysdate,to_char(sysdate+1/24,"yyyy-mm-dd HH24:MI:SS") from dual; --加1小时
select sysdate,to_char(sysdate+1/24/60,"yyyy-mm-dd HH24:MI:SS") from dual; --加1分钟
select sysdate,to_char(sysdate+1/24/60/60,"yyyy-mm-dd HH24:MI:SS") from dual; --加1秒
--------------------------------------------------------------------------------------
select sysdate,add_months(sysdate,-12) from dual; --减1年
select sysdate,add_months(sysdate,-1) from dual; --减1月
select sysdate,to_char(sysdate-7,"yyyy-mm-dd HH24:MI:SS") from dual; --减1星期
select sysdate,to_char(sysdate-1,"yyyy-mm-dd HH24:MI:SS") from dual; --减1天
select sysdate,to_char(sysdate-1/24,"yyyy-mm-dd HH24:MI:SS") from dual; --减1小时
select sysdate,to_char(sysdate-1/24/60,"yyyy-mm-dd HH24:MI:SS") from dual; --减1分钟
select sysdate,to_char(sysdate-1/24/60/60,"yyyy-mm-dd HH24:MI:SS") from dual; --减1秒
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/6992.html