“加一年减一天”与“减一年加一天”的区别

本文探讨了在Oracle中使用日期运算解决脱保车辆查询问题的过程,特别是遇到ORA-01839错误的原因及解决方案。通过实例展示了如何正确处理日期计算避免日期不匹配引发的错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

刚刚写了一个关于脱保车辆的查询语句

大意是将入保时间加一年减一天就是保险到期时间,如果到期时间小于当前时间,则认为是脱保车辆

但是我发现这样的语句不能执行,报ora-01839错误!

select to_char(trunc(’到期时间‘, 'yyyy-mm-dd'))+
                               (INTERVAL '1' YEAR) - (INTERVAL '1' DAY),'yyyy-mm-dd') from dual;

郁闷!之前的语句为什么没事?百思不得其解,去看看数据终于找到‘2012-02-29’就是他的原因,改写sql语句:

select to_char(trunc(’到期时间‘, 'yyyy-mm-dd'))- (INTERVAL '1' DAY)+
                               (INTERVAL '1' YEAR) ,'yyyy-mm-dd') from dual;

ok!没问题了!

联想一下:看来oracle是先将左边的加一年先计算出来再进行减一天的计算,正是因为2012-02-29要计算成2013-02-29才报错(2013年2月份没有第29天)。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值