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

来源:互联网 发布:mp3播放器软件 编辑:程序博客网 时间:2024/06/15 23:56

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

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

但是我发现这样的语句不能执行,报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天)。