cognos实现同期和上月(informix库)【转载】

同期: 

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天

 

转载地址:http://braveheart.me.blog.163.com/blog/static/6171451720093991232350/

posted on 2010-04-26 22:15  星星博客园  阅读(355)  评论(0编辑  收藏  举报

导航

立即注册PayPal并开始接受信用卡付款。