Oracle 时间戳和 current_date

Posted

技术标签:

【中文标题】Oracle 时间戳和 current_date【英文标题】:Oracle timestamp and current_date 【发布时间】:2015-06-04 23:04:12 【问题描述】:

我有这个代码工作:

ixdtl.timestamp between
to_date('2015/06/03', 'YYYY/MM/DD')+ INTERVAL '03:0:0.0' HOUR TO SECOND 
  AND to_date('2015/06/03', 'YYYY/MM/DD')+ INTERVAL '1 2:59:59.99' DAY TO SECOND
    AND 
    (
     icrun.RUNDATE BETWEEN to_date('2015/06/03', 'YYYY/MM/DD')
     AND to_date('2015/06/03', 'YYYY/MM/DD')+ INTERVAL '1' DAY 
     )

但是现在,我需要使用变量 current_date 来代替字符串 '2015/06/03',以便 ixdtl.timestamp 介于昨天凌晨 3 点和今天凌晨 3 点之间。此外,运行日期必须是昨天或今天。

我该怎么做?

【问题讨论】:

【参考方案1】:

CURRENT_DATE 是当前日期和时间。如果您只需要日期部分,请使用TRUNC 函数。

要获得昨天凌晨 3 点和今天凌晨 3 点,可能更容易从今天午夜减去 21 小时得到昨天凌晨 3 点,在今天午夜加上 3 小时得到今天凌晨 3 点,然后使用 >= / BETWEEN

ixdtl.timestamp >= TRUNC(CURRENT_DATE) - INTERVAL '21' HOUR AND
ixdtl.timestamp < TRUNC(CURRENT_DATE) + INTERVAL '3' HOUR

对于今天和昨天,查找 >= 一天前和

ixdtl.RUNDATE >= TRUNC(CURRENT_DATE) - INTERVAL '1' DAY AND
ixdtl.RUNDATE < TRUNC(CURRENT_DATE) + INTERVAL '1' DAY

把它们放在一起,你会得到:

WHERE ixdtl.timestamp >= TRUNC(CURRENT_DATE) - INTERVAL '21' HOUR
  AND ixdtl.timestamp < TRUNC(CURRENT_DATE) + INTERVAL '3' HOUR
  AND ixdtl.RUNDATE >= TRUNC(CURRENT_DATE) - INTERVAL '1' DAY
  AND ixdtl.RUNDATE < TRUNC(CURRENT_DATE) + INTERVAL '1' DAY

【讨论】:

【参考方案2】:

你的谓词应该是:

ixdtl.timestamp
  BETWEEN trunc(CURRENT_DATE) - INTERVAL '21' HOUR
  AND     trunc(CURRENT_DATE) + INTERVAL '3'  HOUR

【讨论】:

以上是关于Oracle 时间戳和 current_date的主要内容,如果未能解决你的问题,请参考以下文章

Oracle SQL - 根据 current_date 更改 WHERE 条件

Oracle-RAC sysdate和current_date时间不一致,导致客户端连接时间延迟

Oracle SQL 当前日期

休眠 current_date 和 date_trunc

将 DB2 日期计算转换为 Oracle 语法

DB2,在尝试计算提供的时间戳和存储的时间戳之间的差异时,出现错误“函数的调用不明确”