oracle 如何查询30天以内的数据?

oracle 查询30天以内的数据 怎么判断?
2025-03-15 09:27:41
推荐回答(5个)
回答1:

以当前的时间为准。分三种情况,一种是以当前时间为中心,算前后共30天;一种是以当前时间为准,算后30天;一种是以当前时间为准,算前30天。

前后共30天:

select * from 表名 where 时间字段 between to_date(sysdate-15,'yyyy-mm-dd') and to_date(sysdate+15,'yyyy-mm-dd');

前30天:

select * from 表名 where 时间字段 between  to_date(sysdate-30,'yyyy-mm-dd') and to_date(sysdate,'yyyy-mm-dd');

后30天:

select * from 表名 where 时间字段 between  to_date(sysdate,'yyyy-mm-dd') and to_date(sysdate+30,'yyyy-mm-dd');

回答2:

最简单的就是这个了。
1、SELECT * FROM HISTORY WHERE to_char(TIME,'yyyymmdd') >= to_char(TIME-30,'yyyymmdd');
来源:商业智能和数据仓库爱好者
提供。。。商业智能和云计算,,,,陪训。。。。包括oracle

回答3:

楼上和楼上的方法我试过不行,不存在HISTORY这个视图,或者说HISTORY是张表的话,那么TIME这个字段不存在,然后3L提出sysdate - 30(我想他是把HISTORY当作表),我也试过,也不行(相反很没依据)。虽然我不知道有什么现成的方法能解决这个问题,但是按照我做过的项目,建表的时候一般都有创建时间字段的,有这个字段就很容易完成楼主的问题啦。

回答4:

select * from a where a.as_of_date between c and d;其中a是表,c和d是日期,注意类型写对就好了

回答5:

sysdate - 30