select * from tb where scbj=0 and to_char(sj,'YYYYMMDD') between to_char((to_char(sysdate,'YYYYMMDD')-14),'YYYYMMDD') and to_char(sysdate,'YYYYMMDD') order by sj,这个是查询从今天到十五天前的数据,现在要让它动态获取时间,就是把sysdate改成动态输入的时间,请问应该怎么改?
最新回答
发光小姐姐
2024-09-18 00:19:07
可以直接通过sysdate之后减去15天的形式来作为条件,之后读取需要的结果。 sql:select * from tablename where create_time>= (sysdate -15); 解释:以上语句中create_time
数据类型
是日期类型,所以减去一个数后还是日期类型。 备注:如果create_time是
字符串
的话,可以通过to_
date函数
转化为日期类型在进行操作。
鬼怪
2024-09-18 04:27:39
在SQL语句中使用变量,可以解决你的问题。 修改后的语句如下,供参考: select * from tb where scbj=0 and to_char(sj,'YYYYMMDD') between to_char((to_char(&x,'YYYYMMDD')-14),'YYYYMMDD') and to_char(&x,'YYYYMMDD') order by sj