分类: DB2/Informix
2011-06-28 14:59:30
CASE
WHEN MONTH(acnt21.date) = 2 AND DAY(acnt21.date) = 29 AND NOT MOD( 1, 4 ) = 0
THEN (acnt21.date + 1 UNITS DAY) + 1 UNITS YEAR - 1 UNITS DAY
ELSE acnt21.date + 1 UNITS YEAR END as date,
目的:在date加上一年
附:四年 闰2月一次为29天,接下来的三年2月均为28天。
所以求同期时,遇到2月29日时,要先加一天(变成3月),再加一年(变成下一年),在减去一天(又变成2月,但是2月28日),其他的日期直接加上一年 即可。
如果不这样做会出现天数溢出问题,举个例子:
2008年2月有29日,接下来3年都有28天,如果在这个日期直接加1年,就成了2009年2月29日,明显的天数溢出,肯定是会报错的,因为2009 年的2月只有28天
上月:
CASE
WHEN DAY((MDY(MONTH(acnt21.date), 1, YEAR(acnt21.date)) + 1 UNITS MONTH) + 1 UNITS MONTH - 1 UNITS DAY ) < DAY(acnt21.date)
then (MDY(MONTH(acnt21.date), 1, YEAR(acnt21.date)) + 1 UNITS MONTH) + 1 UNITS MONTH - 1 UNITS DAY
else acnt21.date + (1) UNITS MONTH END as date
目的:在date上加上一月
附:如果date的下一个月的天数 < date的天数(当月天数),
直接加1我个月的话,就出现天数溢出,所以要加上两个月,再减去一天,就得到了下一个月(这里忽略天)
否则 如果date的下一个月的天数 > date的这个月的天数,就直接加上1个月即可,不会发生天数溢出
举个例子:
2009年3月31,直接加上1个月,就成了2009年4月31了,明显的天数溢出,肯定是会报错的,因为2009年4月只有30天