当前位置:  数据库>oracle

Oracle中将毫秒数转换为timestamp类型的两种方法

    来源: 互联网  发布时间:2017-06-04

    本文导语: 在许多场景中,开发人员习惯用1970-01-01 00:00:00.000以来的毫秒数来表示具体的时间,这样可以将数据以NUMBER类型存储到数据库中,在某些时候方便比较,同样,有些时候我们需要把这种毫秒数转换成标准的TIMESTAMP类型,现在总结...

在许多场景中,开发人员习惯用1970-01-01 00:00:00.000以来的毫秒数来表示具体的时间,这样可以将数据以NUMBER类型存储到数据库中,在某些时候方便比较,同样,有些时候我们需要把这种毫秒数转换成标准的TIMESTAMP类型,现在总结了两种实现方法:

 方法一:
 SELECT TO_TIMESTAMP('1970-01-01 00:00:00.000','yyyy-MM-dd hh24:mi:ss.ff3')+1397457489296/1000/60/60/24 FROM dual;
 这种方法最简单,采用天数相加的方式,效率是比较高的,但是经测试,会丢失毫秒部分的精度,如果对毫秒级精度没有要求,可以采用这种方式。
 方法二:
 这种方法比较复杂,通常需要创建一个函数,但是可以精确保留毫秒级精度!

CREATE OR REPLACE FUNCTION MILLISECONDS2TIMESTAMP(I_MILLISECONDS NUMBER)
 /***************************************************************************************
  名称:MILLISECONDS2TIMESTAMP
  功能:将1970-01-01 00:00:00以来的毫秒数转换为对应的timestamp时间类型,精确保留毫秒级精度!
  参数:I_MILLISECONDS NUMBER  待转换的毫秒数
  示例:select MILLISECONDS2TIMESTAMP(1397457489296) from dual;
  *************************************************************************************/
  RETURN TIMESTAMP AS
  V_TIMESTAMPSTR VARCHAR2(17);
 BEGIN
  SELECT TO_CHAR(TO_TIMESTAMP('1970-01-01', 'yyyy-MM-dd') +
                  TRUNC((I_MILLISECONDS -
                        (MOD((I_MILLISECONDS -
                              (MOD((I_MILLISECONDS -
                                    MOD(I_MILLISECONDS, 1000)) / 1000,
                                    60) * 1000 + MOD(I_MILLISECONDS, 1000))) / 1000 / 60,
                              60) * 60 * 1000 +
                        MOD((I_MILLISECONDS - MOD(I_MILLISECONDS, 1000)) / 1000,
                              60) * 1000 + MOD(I_MILLISECONDS, 1000))) / 1000 / 60 / 60 / 24),
                  'yyyyMMdd') ||--日期
          LPAD(MOD((I_MILLISECONDS -
                  (MOD((I_MILLISECONDS -
                        (MOD((I_MILLISECONDS - MOD(I_MILLISECONDS, 1000)) / 1000,
                              60) * 1000 + MOD(I_MILLISECONDS, 1000))) / 1000 / 60,
                        60) * 60 * 1000 +
                  MOD((I_MILLISECONDS - MOD(I_MILLISECONDS, 1000)) / 1000,
                        60) * 1000 + MOD(I_MILLISECONDS, 1000))) / 1000 / 60 / 60,
                  24),
              2,
              0) || --小时
          LPAD(MOD((I_MILLISECONDS -
                  (MOD((I_MILLISECONDS - MOD(I_MILLISECONDS, 1000)) / 1000,
                        60) * 1000 + MOD(I_MILLISECONDS, 1000))) / 1000 / 60,
                  60),
              2,
              0) || --分钟
          LPAD(MOD((I_MILLISECONDS - MOD(I_MILLISECONDS, 1000)) / 1000, 60),
              2,
              0) || --秒
          LPAD(MOD(I_MILLISECONDS, 1000), 3, 0) --毫秒
    INTO V_TIMESTAMPSTR
    FROM DUAL;
  RETURN TO_TIMESTAMP(V_TIMESTAMPSTR, 'yyyyMMddhh24missff3');
 EXCEPTION
  WHEN OTHERS THEN
    RETURN NULL;
 END;


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 在oracle里如何将String转换成Date?????
  • 请问:ORACLE中的数据取出来后,需不需要进行一定的转换才能变为C语言的数据类型啊?
  • ORACLE 毫秒与日期的相互转换示例
  • 用java怎样实现oracle数据库表和excel数据表的转换
  • 数据库 iis7站长之家
  • Oracle下时间转换在几种语言中的实现
  • 关于tomcat4.0.1+JDK1.3+ORACLE+JDBC中字符编码的转换问题。
  • MySQL转换Oracle的需要注意的七个事项
  • MySQL数据库向Oracle转换时注意若干问题
  • Oracle Number型数值存储与转换的实现详解
  • 讲解Oracle中的Clob与String类型转换
  • 将mysql转换到oracle必须了解的50件事
  • oracle中to_date详细用法示例(oracle日期格式转换)
  • ORACLE常用数值函数、转换函数、字符串函数
  • Oracle CBO几种基本的查询转换详解
  • Oracle to_char 日期转换字符串语句分享
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,