网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>数据库技术>>Oracle技术>>Oracle开发>查看文档  
  oracle data的一个常见问题计算时间差     
  文章作者:未知  文章来源:赛迪网技术社区  
  查看:105次  录入:管理员--2008-01-28  
 

计算时间差是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)- 消逝的时间(以分钟为单位)。

显示时间差的默认模式是什么?为了找到这个问题的答案,让我们进行一个简单的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)系统级触发机制来计算已经开始的会话时间并把它放入一个oraclestatspack 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;

 
 
上一篇: 非阻塞算法思想在数据库开发中的应用    下一篇: 快速掌握在oracle 9i中转换时区的方法
  相关文档
深入讲解"alert log"过大时的处理方法 03-14
通过进行正规化的表格设计提升应用性能 (1) 06-03
融会贯通oracle数据库的25条基本知识 02-29
配置windows与linux平台的data gurad (1) 05-28
详细讲解oracle i/o子系统的配置和设计 (1) 04-30
讲解oracle数据库的sysdba权限登录问题 (1) 06-05
如何对存储过程返回的结果进行条件查询 02-28
详细讲解oracle数据库sys密码的找回方法 08-01
Oracle9i的新特性索引跳跃式扫描的实现 09-01
如何获取指定表中指定字段内的可用编号 04-23
Oracle的远程复制与异地容灾的经典解析 09-01
oracle数据库环境下数据文件丢失的恢复 07-25
用一个示例讲解自治事务和非自治事务的区别 07-25
Oracle数据库中单行字符串函数简介 04-11
"physical standby"置于read/write状态 03-05
如何让oracle数据库始终保持优良性能 04-29
用Oracle 10g列值掩码技术隐藏敏感数据 04-11
Oracle DBA数据库日常维护完全手册 04-23
通过rman backup as copy移动数据文件 03-06
利用Oracle执行计划机制提高查询性能 04-11
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
厦门(总部):13616026886 福州:0591-87655121
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息