haoxin.yuan 2017-08-25 08:10 采纳率: 100%
浏览 6867
已采纳

Oracle中怎么计算出两个timestamp类型相差的毫秒数

表中有开始时间和结束时间,两个都是timestamp类型,直接相减得到+000000000 00:00:00.513000这种类型,我想得到的数据类型为100000这样的毫秒数,求教如何写

  • 写回答

5条回答 默认 最新

  • cloudyzhao 2017-08-25 16:30
    关注

    CREATE OR REPLACE FUNCTION uf_timestamp_diff(endtime in TIMESTAMP,starttime in TIMESTAMP)

    RETURN INTEGER

    AS

    str VARCHAR2(50);

    misecond INTEGER;

    seconds INTEGER;

    minutes INTEGER;

    hours INTEGER;

    days INTEGER;

    BEGIN

    str:=to_char(endtime-starttime);

    misecond:=to_number(SUBSTR(str,INSTR(str,' ')+10,3));

    seconds:=to_number(SUBSTR(str,INSTR(str,' ')+7,2));

    minutes:=to_number(SUBSTR(str,INSTR(str,' ')+4,2));

    hours:=to_number(SUBSTR(str,INSTR(str,' ')+1,2));

    days:=to_number(SUBSTR(str,1,INSTR(str,' ')));

    RETURN days*24*60*60*1000+hours*60*60*1000+minutes*60*1000+seconds*1000+misecond;  
    

    END;

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 oracle集群安装出bug
  • ¥15 关于#python#的问题:自动化测试