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

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 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥15 复杂网络,变滞后传递熵,FDA
  • ¥20 csv格式数据集预处理及模型选择
  • ¥15 部分网页页面无法显示!
  • ¥15 怎样解决power bi 中设置管理聚合,详细信息表和详细信息列显示灰色,而不能选择相应的内容呢?
  • ¥15 QTOF MSE数据分析
  • ¥15 平板录音机录音问题解决