oracle中计算两个日期的相差天数月数年数小时数分钟数秒数等

Posted 乃颜先生

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle中计算两个日期的相差天数月数年数小时数分钟数秒数等相关的知识,希望对你有一定的参考价值。

oracle如何计算两个日期的相差天数、月数、年数、小时数、分钟数、秒数

1、相差天数(两个日期相减)

--Oracle中两个日期相差天数--
select TO_NUMBER(TO_DATE(\'2018-6-5\',\'yyyy-mm-dd hh24:mi:ss\')- TO_DATE(\'2018-5-31\',\'yyyy-mm-dd hh24:mi:ss\'))
AS 相差天数 from dual;

2、相差小时数、分钟数、秒数

--Oracle中两个日期相差小时数--
select TO_NUMBER((TO_DATE(\'2018-6-5\',\'yyyy-mm-dd hh24:mi:ss\')- TO_DATE(\'2018-5-31\',\'yyyy-mm-dd hh24:mi:ss\'))*24)
AS 相差小时数 from dual;

--Oracle中两个日期相差分钟数--
select TO_NUMBER((TO_DATE(\'2018-6-5\',\'yyyy-mm-dd hh24:mi:ss\')- TO_DATE(\'2018-5-31\',\'yyyy-mm-dd hh24:mi:ss\'))*24*60)
AS 相差分钟数 from dual;

--Oracle中两个日期相差秒数--
select TO_NUMBER((TO_DATE(\'2018-6-5\',\'yyyy-mm-dd hh24:mi:ss\')- TO_DATE(\'2018-5-31\',\'yyyy-mm-dd hh24:mi:ss\'))*24*60*60)
AS 相差秒数 from dual;

3、相差月数(months_between()函数)

--oracle两个日期的相差月数--
--1)月份都是最后一天,A日期 > B日期 ,返回整数 ---
select months_between(TO_DATE(\'2018-6-30\',\'yyyy-mm-dd hh24:mi:ss\'),TO_DATE(\'2018-5-31\',\'yyyy-mm-dd hh24:mi:ss\'))
As 相差月份1 from dual;

--2)月份都是最后一天,B日期 > A日期 ,返回负数 ---
select months_between(TO_DATE(\'2018-4-30\',\'yyyy-mm-dd hh24:mi:ss\'),TO_DATE(\'2018-5-31\',\'yyyy-mm-dd hh24:mi:ss\'))
As 相差月份2 from dual;

--3)月份天数不一样,A日期 > B日期 ,返回带小数的数字---
select months_between(TO_DATE(\'2018-6-25\',\'yyyy-mm-dd hh24:mi:ss\'),TO_DATE(\'2018-5-31\',\'yyyy-mm-dd hh24:mi:ss\'))
As 相差月份3 from dual;

4.相差年数(原先月数/12)

--oracle两个日期的相差年份--
select ((months_between(TO_DATE(\'2018-5-31\',\'yyyy-mm-dd hh24:mi:ss\'),TO_DATE(\'2016-5-31\',\'yyyy-mm-dd hh24:mi:ss\')))/12)
As 相差年份 from dual;

 

以上是关于oracle中计算两个日期的相差天数月数年数小时数分钟数秒数等的主要内容,如果未能解决你的问题,请参考以下文章

Java计算两个日期时间相差几天,几小时,几分钟等

Java计算两个日期时间相差几天,几小时,几分钟等

MySql计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数

java计算两个日期相差多少天小时分钟等

MySql计算两日期时间之间相差的天数,秒数,分钟数,周数,小时数

oracle 日期计算