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 matlab有关常微分方程的问题求解决
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算
  • ¥15 java如何提取出pdf里的文字?
  • ¥100 求三轴之间相互配合画圆以及直线的算法
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable