5个回答
展开全部
以当前的时间为准。分三种情况,一种是以当前时间为中心,算前后共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');
展开全部
最简单的就是这个了。
1、SELECT * FROM HISTORY WHERE to_char(TIME,'yyyymmdd') >= to_char(TIME-30,'yyyymmdd');
来源:商业智能和数据仓库爱好者
提供。。。商业智能和云计算,,,,陪训。。。。包括oracle
1、SELECT * FROM HISTORY WHERE to_char(TIME,'yyyymmdd') >= to_char(TIME-30,'yyyymmdd');
来源:商业智能和数据仓库爱好者
提供。。。商业智能和云计算,,,,陪训。。。。包括oracle
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
楼上和楼上的方法我试过不行,不存在HISTORY这个视图,或者说HISTORY是张表的话,那么TIME这个字段不存在,然后3L提出sysdate - 30(我想他是把HISTORY当作表),我也试过,也不行(相反很没依据)。虽然我不知道有什么现成的方法能解决这个问题,但是按照我做过的项目,建表的时候一般都有创建时间字段的,有这个字段就很容易完成楼主的问题啦。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
select * from a where a.as_of_date between c and d;其中a是表,c和d是日期,注意类型写对就好了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
sysdate - 30
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询