首页 ┆ 网站地图 ┆ 在线留言 ┆ 游戏资讯 ┆ 资源下载 ┆ 端午节祝福 ┆ 迅雷在线影视
设为首页
加入收藏
联系我们
高级搜索
您当前的位置: 主页>数据库>ORACLE>Oracle数据库中时间问题的一些比较
Oracle数据库中时间问题的一些比较
来源: 发布时间:2008-09-18 发布人: 浏览: 人次   字体: [ ]  
         在以前的版本中,Oracle的时间计量单位是厘秒,使用厘秒最显而易见的问题就是可能有些操作是小于厘秒的。看上去这似乎不太常见,但是实际上在操作系统上很多操作都是以微妙作为单位的,这意味着操作的起始和终止在不到厘秒就完成了,从厘秒级看就好像没有发生一样,因为持续时间近似为0。而有时候操作的持续时间不到厘秒,但是起始和终止发生在两个相连的厘秒,所以操作时间不到厘秒但是却被记录为厘秒,造成时间记录的不准确。Oracle没有内置的方式来记录时间的流逝。DATE型数据用来记录单独的时间点;但是要表达一个时间量(也就是一个间隔),数据库的设计者就必须把时间间隔转换成原始单位秒,然后用一个NUMBER列来保存它。

  虽然NUMBER这个数据类型可以以秒为单位准确地表示时间,但是它使得时间的计算变得很困难。比如,60秒是1分钟,60分钟是1个小时,24个小时等于1天——这些数字在以十进制为基础的数字系统中都是非常不实用的。

  在Oracle中,按照SQL 99标准,增加了时间间隔型数据INTERVAL YEAR TO MONTH 和INTERVALDAY TO SECOND,它们和其他几种数据类型一起使得对时间的处理更加准确。TIMESTAMP、TIMESTAMPWITHTIME ZONE和TIMESTAMP WITH LOCALTIMEZONE等数据类型都把时间的表达精确到了若干分之一秒,而且后面两种还解决了地理位置造成的时间变化。

  Sql语句的等待时间等于ELAPSED_TIME减去CPU_TIME,但是很难看到精确的等待时间。在V$SYSTEM_EVENT视图中能够看到数据库实例级的等待时间(并不是每条Sql语句的),但是看不到发生在操作系统上的等待时间。

  在SQL和PL/SQL中,你都可以用时间间隔型数据,它们都是用同一种方式规定的:

  INTERVALYEAR(year_precision)TOMONTH

  INTERVALDAY(day_precision)TOSECOND(fractional_seconds_precision)

  转换函数,与date操作关系最大的就是两个转换函数:to_date(),to_char()

  to_date() 作用将字符类型按一定格式转化为日期类型:

  具体用法:to_date("2008-11-27","yyyy-mm-dd"),前者为字符串,后者为转换日期格式,注意,前后两者要以一对应。

  如;to_date("2008-11-27 13:34:43", "yyyy-mm-ddhh24:mi:ss")将得到具体的时间

  对于精确数值,规定有缺省值:年和日是两位数,若干分之一秒是六位数。

  时间间隔的大小由INTERVAL来表示,后面紧接一个放在单引号中的表达式,以及用来解释该表达式的文字。用YEARTOMONTH表示时间间隔大小时要在年和月之间用一个连字符(-) 连接。而DAYTOSECOND表示时间间隔大小时要在日和时间之间用一个空格连接。例子如下:

  返回当前时间 年月日小时分秒毫秒

  selectto_char(current_timestamp(5),"DD-MON-YYYYHH24:MI:SSxFF")fromdual;

  返回当前 时间的秒毫秒,可以指定秒后面的精度(最大=9)

  selectto_char(current_timestamp(9),"MI:SSxFF")fromdual;

  实现最大值与当前时间的比较


相 关 文 章   发布商链接
·迁移ORACLE数据文件的几种常用方式
·ORACLE实现字符串截取的功能
·Oracle9i重命名机器名后不能启动的解...
·如何修改Oracle的默认端口8080?
·如何在Oracle数据库中创建表和视图?
·解析Oracle中限制返回结果集的大小
·用Oracle 10g列值掩码技术隐藏敏感数...
·Oracle巧取指定记录以及巧用外关联...
·ORACLE使用中的常见、实用的问题技巧
·oracle数据库导入Excel数据方法
 §最新评论:(评论内容只代表网友观点,与本站立场无关!)
网名: 验证码:  【所有评论】【↑返回顶部
评 分: 12 345
评论内容:(不能超过500字,请自觉遵守互联网相关政策法规。[按 Ctrl+Enter 可直接提交]
注意:请勿在本站发布政治话题、色情及违反法律的内容。
IT知道网 声明:刊登此文章是为了传递更多信息,文章内容仅供参考,转载请注明出处。
推 荐 文 章
·Oracle数据库临时表的管理及...
·Oracle中to_date函数的详细使
·Oracle导致CPU进程100%原因及
·实例讲解对oracle进行简单树...
·Oracle服务费是如何计算的,以...
·如何完全清除Oracle
·ORACLE 10G分区表维护:全局...
·怎样有效提高Oracle 10G增量...
·Oracle数据库的四种启动方式...
·利用函数实现oracle行列转换
·使用type类型和存储过程来完...
·oracle9i客户端如何连接oracl...
·解决ORACLE被锁定的资源两法
·oracle中分割字符串,并求最...
·详细讲解Oracle数据库灾难防...
热 门 文 章
·Oracle内连接、外连接、右外...
·oracle分析函数row_number的...
·ORACLE使用中的常见、实用的...
·oracle9i客户端如何连接oracl...
·如何完全清除Oracle
·利用函数实现oracle行列转换
·导入、导出oracle数据库与复...
·ORACLE 10G分区表维护:全局...
·oracle中分割字符串,并求最...
·ORACLE实现字符串截取的功能
·几个方面入手oracle性能优化...
·使用type类型和存储过程来完...
·实例讲解对oracle进行简单树...
·Oracle中to_date函数的详细使...
·oracle数据库中如何修改字段...
网站首页 - 关于本站 - 加入收藏 - 网站地图 - 友情连接 - 在线留言 - 联系我们 - 返回顶部
Copyright © 2007 IT知道网.[冀ICP备07026896号]. All Rights Reserved .