在oracle中计算时间差

简介:
计算时间差是oracle data数据类型的一个常见问题。oracle支持日期计算你可以创建诸如“日期1日期2”这样的表达式来计算这两个日期之间的时间差。

一旦你发现了时间差异你可以使用简单的技巧来以天、小时、分钟或者秒为单位来计算时间差。为了得到数据差你必须选择合适的时间度量单位这样就可以进行数据格式隐藏。

使用完善复杂的转换函数来转换日期是一个诱惑但是你会发现这不是最好的解决方法。
round(to_number(end-date-start_date))- 消逝的时间以天为单位

round(to_number(end-date-start_date)*24)- 消逝的时间以小时为单位

round(to_number(end-date-start_date)*1440)- 消逝的时间以分钟为单位K7zR{{-:W[本资料来源于贵州学习网 http://www.gzu521.com]K7zR{{-:W
显示时间差的默认模式是什么为了找到这个问题的答案让我们进行一个简单的sql *plus查询。
sql> select sysdate-(sysdate-3) from dual;

sysdate-(sysdate-3)
-------------------
3
这里我们看到了oracle使用天来作为消逝时间的单位所以我们可以很容易的使用转换函数来把它转换成小时或者分钟。然而当分钟数不是一个整数时我们就会遇到放置小数点的问题。
select
(sysdate-(sysdate-3.111))*1440
from
dual;


(sysdate-(sysdate-3.111))*1440
------------------------------
4479.83333
当然我们可以用round函数即取整函数来解决这个问题但是要记住我们必须首先把date数据类型转换成number数据类型。
select
round(to_number(sysdate-(sysdate-3.111))*1440)
from
dual;

round(to_number(sysdate-(sysdate-3.111))*1440)
----------------------------------------------
4480
我们可以用这些函数把一个消逝时间近似转换成分钟并把这个值写入oracle表格中。在这个例子里我们有一个离线logoff系统级触发机制来计算已经开始的会话时间并把它放入一个oracle statspack user_log扩展表格之中。
update
perfstat.stats$user_log
set
elapsed_minutes =
round(to_number(logoff_time-logon_time)*1440)
where
user = user_id
and
elapsed_minutes is null;
目录
相关文章
|
9月前
|
监控 Oracle 关系型数据库
Oracle 计算时间差
Oracle 计算时间差
47 0
|
SQL Oracle 关系型数据库
Oracle SQL 求两个时间差
Oracle SQL 求两个时间差
|
Oracle 关系型数据库
oracle里如何将两个日期的时间差返回**时**分的格式
SELECT EXTRACT(DAY FROM (sysdate-to_date('2012-03-29 00:00:00','YYYY-MM-DD HH24:MI:ss')) DAY TO SECOND ) || ' days ' || EXTRACT(HOUR FR...
736 0
|
Oracle 关系型数据库 数据格式
在oracle中计算时间差
计算时间差是oracle data数据类型的一个常见问题。oracle支持日期计算,你可以创建诸如“日期1-日期2”这样的表达式来计算这两个日期之间的时间差。 一旦你发现了时间差异,你可以使用简单的技巧来以天、小时、分钟或者秒为单位来计算时间差。
1233 0
|
13天前
|
SQL Oracle 关系型数据库
【Oracle】玩转Oracle数据库(一):装上去,飞起来!
【Oracle】玩转Oracle数据库(一):装上去,飞起来!
56 7
|
1月前
|
Oracle 关系型数据库 数据库
|
1月前
|
关系型数据库 分布式数据库 数据库
PolarDB PostgreSQL版:Oracle兼容的高性能数据库
PolarDB PostgreSQL版是一款高性能的数据库,具有与Oracle兼容的特性。它采用了分布式架构,可以轻松处理大量的数据,同时还支持多种数据类型和函数,具有高可用性和可扩展性。它还提供了丰富的管理工具和性能优化功能,为企业提供了可靠的数据存储和处理解决方案。PolarDB PostgreSQL版在数据库领域具有很高的竞争力,可以满足各种企业的需求。
|
1月前
|
Oracle 关系型数据库 数据库
Oracle数据库基本概念理解(3)
Oracle数据库基本概念理解(3)
18 2
|
1月前
|
Oracle 关系型数据库 数据库
如何利用 Docker 安装 Oracle 数据库
【2月更文挑战第14天】
93 0
|
13天前
|
SQL Oracle 关系型数据库
【Oracle】玩转Oracle数据库(七):RMAN恢复管理器
【Oracle】玩转Oracle数据库(七):RMAN恢复管理器
41 5

推荐镜像

更多