Oracle SQL语句动态获取十五天内的数据
select*fromtbwherescbj=0andto_char(sj,'YYYYMMDD')betweento_char((to_char(sysdate,'YYY...
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改成动态输入的时间,请问应该怎么改? 展开
to_char((to_char(sysdate,'YYYYMMDD')-14),'YYYYMMDD') and
to_char(sysdate,'YYYYMMDD') order by
sj,这个是查询从今天到十五天前的数据,现在要让它动态获取时间,就是把sysdate改成动态输入的时间,请问应该怎么改? 展开
5个回答
展开全部
在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
修改后的语句如下,供参考:
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
更多追问追答
追问
&x是什么?
追答
&符号代表从键盘终端输入一个值,x只是一个变量名字,随便起的。
你在SQL/PLUS下运行这个语句,然后输入一个日期试试。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
定义一个输入类,获取你输入时间的字符串,然后通过parse方法将字符串转换为Date对象
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你是什么软件做后台?to_char(sysdate,'YYYYMMDD')-14 其中的14改成一个变量就行了。或者吧整条sql放到存储过程中,存int参数,替换其中的14这个整数
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-10-14
展开全部
select * from tb where scbj=0 and to_char(sj,'YYYYMMDD') between
to_char((to_char(v_date,'YYYYMMDD')-14),'YYYYMMDD') and
to_char(v_date,'YYYYMMDD')
where v_date ='&input_date'
order by sj;
不知道我理解的对不对,貌似是替代变量吧
to_char((to_char(v_date,'YYYYMMDD')-14),'YYYYMMDD') and
to_char(v_date,'YYYYMMDD')
where v_date ='&input_date'
order by sj;
不知道我理解的对不对,貌似是替代变量吧
追问
不对啊,日期不对,where 后面的那个也不对
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |