Chinaunix首页 | 论坛 | 博客
  • 博客访问: 8350723
  • 博文数量: 444
  • 博客积分: 10593
  • 博客等级: 上将
  • 技术积分: 3852
  • 用 户 组: 普通用户
  • 注册时间: 2006-05-09 15:26
文章分类

全部博文(444)

文章存档

2014年(1)

2013年(10)

2012年(18)

2011年(35)

2010年(125)

2009年(108)

2008年(52)

2007年(72)

2006年(23)

分类: 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天

阅读(2469) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~