如何写一个查询从准确的25分钟到15分钟后取数据? Oracle sql

时间:2017-03-20 19:51:10

标签: sql database oracle

我有一个如下的查询;

SELECT fielda,fieldb,fieldc  
from mytable 
where timefield between to_date((to_char(sysdate-1/24, 'DD-MON-YYYY HH24') || ':00:00'), 'DD-MON-YYYY HH24:MI:SS') 
                    and to_date((to_char(sysdate-1/24, 'DD-MON-YYYY HH24') || ':59:59'), 'DD-MON-YYYY HH24:MI:SS');

此查询从前一小时前的059小时开始计算值。我想要的是,我想运行一个在第10分钟运行的查询。查询应该从我的表中获取行,其中时间介于25分钟和15分钟之间。例如,我在09:10:00和几秒钟内运行查询。它应该获取时间段在08:50和08:59:00之间的行(我希望在8:50和8:59中包含数据)。我怎么能这样做?

2 个答案:

答案 0 :(得分:2)

您将SYSDATE截断为分钟并减去所需的间隔。使用>=<来正确处理秒数和分数。

select fielda, fieldb, fieldc
from mytable 
where timefield >= trunc(sysdate, 'minute') - interval '25' minute
  and timefield <  trunc(sysdate, 'minute') - interval '20' minute;

答案 1 :(得分:0)

SELECT *
FROM mytable 
WHERE timefield >= sysdate - (25/1440)
  AND timefield <= sysdate - (10/1440)
  

24 * 60 = 1440