设为首页 收藏本站
查看: 1135|回复: 0

[经验分享] DB2中求两个日期之间相差多少个月?

[复制链接]

尚未签到

发表于 2016-11-16 09:26:06 | 显示全部楼层 |阅读模式
  DB2中怎么来求两个日期之间相差多少个月呢?
今天在工作中遇到一个问题,就是怎么在DB2中怎么来求两个日期之间相差多少个月呢?
结果找到一个方法如下:
在DB2中两个日期之间相减会等到一个整数总共有六种情况分别是:

select date('2010-1-30')-date('2010-1-1') from RATE_INFO;

  
查询结果是:29
29代表的意思是  29天


select date('2010-10-1')-date('2010-1-1') from RATE_INFO;

  
查询结果是:900
900代表的意思是  9个月0天


select date('2010-12-3')-date('2010-1-1') from RATE_INFO;
  
查询结果是:1102
1102代表的意思是  11个月2天


select date('2011-10-1')-date('2010-1-1') from RATE_INFO;

  
查询结果是:10900
10900代表的意思是  1年9个月0天


select date('2020-10-1')-date('2010-1-1') from RATE_INFO;

  
查询结果是:100900
100900代表的意思是  10年9个月0天
总结起来是: 个位、十位用来表示相差多少天
             百位、千位用来表示相差多少月
             万位、十万位用来表示相差多少年

我自己写了一个函数用来计算两个日期之间相差多少个月

-- 计算两个日期之间相差多少个月,如果有零星的天数,则加上一个月

create function monthBetween("DAY1" varchar(10),"DAY2" varchar(10))
Returns INTEGER
LANGUAGE SQL
begin ATOMIC Declare dMonth INTEGER;
Declare date1 Date;
Declare date2 Date;
Declare a INTEGER;
--我们这里将传入的day1,day2进行比较,将日期大的赋值给date1,反之赋值给date2
if day1>day2 then
set date1=Date(day1);
set date2=Date(day2);
else
set date1=Date(day2);
set date2=Date(day1);
end if;
set a = (date1-date2);
if  mod(a,100)>0 then --如果有零星天,即天数大于零则月数加上1
set dMonth=(date1-date2)/10000*12+ mod((a/100),100)+1;
else
set dMonth=(date1-date2)/10000*12+mod((a/100),100);
end if;
return dMonth;
end

  
   
  拿出来分享一下,希望对大家有所帮助

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-301024-1-1.html 上篇帖子: DB2 maxappls, maxagents, max_coordagents, max_connections参数的配置 下篇帖子: 如何把orcale的数据导入到DB2
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表