计算时间差是oracle data数据类型的一个常见问题.oracle支持日期计算,你可以创建诸如“日期1-日期2”这样的表达式来计算这两个日期之间的时间差.
使用完善复杂的转换函数来转换日期是一个诱惑,但是你会发现这不是最好的解决方法. 【程序编程相关:PHP 和 MySQL 开发的8个技巧】
一旦你发现了时间差异,你可以使用简单的技巧来以天.小时.分钟或者秒为单位来计算时间差.为了得到数据差,你必须选择合适的时间度量单位,这样就可以进行数据格式隐藏. 【推荐阅读:如何设置 MySql 数据同步】round(to_number(end-date-start_date)*24)- 消逝的时间(以小时为单位) 【扩展信息:My SQL数据库引擎快速指导】
round(to_number(end-date-start_date))- 消逝的时间(以天为单位)
round(to_number(end-date-start_date)*1440)- 消逝的时间(以分钟为单位)
显示时间差的默认模式是什么?为了找到这个问题的答案,让我们进行一个简单的sql *plus查询.
sql> select sysdate-(sysdate-3) from dual;
sysdate-(sysdate-3)
-------------------3这里,我们看到了oracle使用天来作为消逝时间的单位,所以我们可以很容易的使用转换函数来把它转换成小时或者分钟.然而,当分钟数不是一个整数时,我们就会遇到放置小数点的问题.
select
(sysdate-(sysdate-3.111))*1440fromdual;... 下一页