Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/date/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Oracle 神谕两个日期,以分钟为单位_Oracle_Date_Difference - Fatal编程技术网

Oracle 神谕两个日期,以分钟为单位

Oracle 神谕两个日期,以分钟为单位,oracle,date,difference,Oracle,Date,Difference,我想获得sysdate和utcdate之间以分钟为单位的整数差。这不起作用: select ROUND((sysdate-SYS_EXTRACT_UTC(SYSTIMESTAMP))*1440,0) from dual 它给出了错误消息: ORA-00932:不一致的数据类型:预期的获取时间间隔为天到秒 脚本第21行,语句第1行,第52列 怎么办?非常感谢 试试这个。必须先将systimestamp数据类型转换为日期类型,然后才能对这两个日期进行计算。也许有一个更优雅的解决方案,但这似乎是可行

我想获得sysdate和utcdate之间以分钟为单位的整数差。这不起作用:

select ROUND((sysdate-SYS_EXTRACT_UTC(SYSTIMESTAMP))*1440,0) from dual
它给出了错误消息: ORA-00932:不一致的数据类型:预期的获取时间间隔为天到秒 脚本第21行,语句第1行,第52列


怎么办?非常感谢

试试这个。必须先将systimestamp数据类型转换为日期类型,然后才能对这两个日期进行计算。也许有一个更优雅的解决方案,但这似乎是可行的

SELECT ROUND (  (  SYSDATE
                 - TO_DATE (TO_CHAR (SYS_EXTRACT_UTC (SYSTIMESTAMP),
                                     'YYYY-MON-DD HH24:MI:SS'
                                    ),
                            'YYYY-MON-DD HH24:MI:SS'
                           )
                )
              * 1440,
              0
             )
  FROM DUAL

试试这个。必须先将systimestamp数据类型转换为日期类型,然后才能对这两个日期进行计算。也许有一个更优雅的解决方案,但这似乎是可行的

SELECT ROUND (  (  SYSDATE
                 - TO_DATE (TO_CHAR (SYS_EXTRACT_UTC (SYSTIMESTAMP),
                                     'YYYY-MON-DD HH24:MI:SS'
                                    ),
                            'YYYY-MON-DD HH24:MI:SS'
                           )
                )
              * 1440,
              0
             )
  FROM DUAL

可以简化一点<代码>(sysdate-cast(SYS\u EXTRACT\u UTC(SYSTIMESTAMP)as date))*1440。在这种情况下真的不需要来回转换。谢谢,这样更干净。可以简化一点<代码>(sysdate-cast(SYS\u EXTRACT\u UTC(SYSTIMESTAMP)as date))*1440。在这种情况下真的不需要来回转换。谢谢,这样更干净。