在Oracle数据库常用的日期与时间的计算
一、计算月份差值
select months_between(date'2016-12-18',date'2017-04-18') between_month from dual;
计算 2016-12-18 与 2017-04-08 之间相差了几个月
运行结果为 相差了 4个月
二、获取两时间的相差豪秒数
select ceil((To_date('2008-05-02 00:00:00', 'yyyy-mm-dd hh24-mi-ss') -
To_date('2008-04-30 23:59:59', 'yyyy-mm-dd hh24-mi-ss')) * 24 * 60 * 60 * 1000) 相差豪秒数
FROM DUAL;
运行结果为 两个时间的毫秒数差值
三 、获取两时间的相差分钟数
select ceil(((To_date('2008-05-02 00:00:00', 'yyyy-mm-dd hh24-mi-ss') -
To_date('2008-04-30 23:59:59', 'yyyy-mm-dd hh24-mi-ss'))) * 24 * 60) 相差分钟数
FROM DUAL;
运行结果为两个时间之间相差的分钟数
四、获取两时间的相差小时数
select ceil((To_date('2008-05-02 00:00:00', 'yyyy-mm-dd hh24-mi-ss') -
To_date('2008-04-30 23:59:59', 'yyyy-mm-dd hh24-mi-ss')) * 24) 相差小时数
FROM DUAL;
运行结果为两个时间之间相差的小时数
五、获取两时间的相差天数
select ceil((To_date('2008-05-02 00:00:00', 'yyyy-mm-dd hh24-mi-ss') -
To_date('2008-04-30 23:59:59', 'yyyy-mm-dd hh24-mi-ss'))) 相差天数
FROM DUAL;
运行结果为两日期相差的天数
六、获取两时间年份差
select EXTRACT(year FROM to_date('2009-05-01', 'yyyy-mm-dd')) -
EXTRACT(year FROM to_date('2008-04-30', 'yyyy-mm-dd')) years
from dual;
运行结果为两日期相差的年份数