select to_char(sysdate, 'yyyymmdd')-21 from dual;得到的结果是20130299 这个问题应该怎么解决,急!!

如问题所述怎样让to_char(sysdate,'yyyymmdd')-21=‘20120228’或者是to_char(sysdate,'yyyymm')-3=20121... 如问题所述怎样让
to_char(sysdate, 'yyyymmdd')-21 =‘20120228’或者是
to_char(sysdate, 'yyyymm')-3=201212而不是201300
日期相减得到正确的数值这个我已经会了,现在想知道to_char(sysdate, 'yyyymm')-3怎样才能得到正确的月份而不是201300,谢谢
展开
 我来答
eun007
2013-03-20 · TA获得超过798个赞
知道小有建树答主
回答量:306
采纳率:0%
帮助的人:229万
展开全部
要在格式化之前减才是日期计算,格式化之后减就是数字计算了
to_char(sysdate-21, 'yyyymmdd')
追问
不是这样的日期内相减是sysdate的减'yyyy-mm-dd'而不是'yyyymmdd'这种格式的减法的结果,我的意思是怎样让运算结果转换成正确的月份,to_char(trunc(sysdate)-4, 'yyyymmdd')这种格式能得到正确的日期,
追答
to_char不就是用来格式化的吗?月份计算用add_months
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
badkano
2013-03-20 · 知道合伙人体育行家
badkano
知道合伙人体育行家
采纳数:144776 获赞数:885372
团长

向TA提问 私信TA
展开全部
把-21放在sysdate里减不就好了吗
select to_char(sysdate-21,'yyyymmdd') from dual

select to_char(sysdate-3,'yyyymm') from dual
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式