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

[经验分享] Sql加减日、月、年

[复制链接]

尚未签到

发表于 2016-11-22 05:51:22 | 显示全部楼层 |阅读模式
  对日期加减日、月、年。例如,根据员工CLARK的HIREDATE(聘用日期),计算另外6个不同的日期: 聘用CLARK之前及之后的5天;聘用CLARK之前及之后的5个月;聘用CLARK之前及之后的5年。例如,聘用CLARK的日期为“09-JUN- 1981”,要求返回如下结果集:
  HD_MINUS_5D    HD_PLUS_5D       HD_MINUS_5M    HD_PLUS_5M      HD_MINUS_5Y    HD_PLUS_5Y
  -----------       -----------       -----------       -----------       -----------       -----------
  04-JUN-1981  14-JUN-1981  09-JAN-1981  09-NOV-1981 09-JUN-1976  09-JUN-1986
  12-NOV-1981 22-NOV-1981 17-JUN-1981  17-APR-1982 17-NOV-1976 17-NOV-1986
  18-JAN-1982  28-JAN-1982  23-AUG-1981 23-JUN-1982  23-JAN-1977  23-JAN-1987
  解决方案
  DB2
  对日期值,允许进行标准的加、减操作,但是,如果对日期进行加减操作,后面一定要给出它所表示的时间单位:
  1 select hiredate -5 day       as hd_minus_5D,
  2        hiredate +5 day        as hd_plus_5D,
  3        hiredate -5 month       as hd_minus_5M,
  4        hiredate +5 month       as hd_plus_5M,
  5        hiredate -5 year  as hd_minus_5Y,
  6        hiredate +5 year         as hd_plus_5Y
  7   from emp
  8  where deptno = 10
  Oracle
  对天数采用标准加减,而使用ADD_MONTHS 函数加减月数和年数:
  1 select hiredate-5                 as hd_minus_5D,
  2        hiredate+5                    as hd_plus_5D,
  3        add_months(hiredate,-5)          as hd_minus_5M,
  4        add_months(hiredate,5)          as hd_plus_5M,
  5        add_months(hiredate,-5*12)       as hd_minus_5Y,
  6        add_months(hiredate,5*12)       as hd_plus_5Y
  7   from emp
  8  where deptno = 10
  PostgreSQL
  同时使用标准加减与INTERVAL关键字,INTERVAL指定时间单位。在指定INTERVAL值时,需要用单引号:
  1 select hiredate - interval '5 day'       as hd_minus_5D,
  2        hiredate + interval '5 day'         as hd_plus_5D,
  3        hiredate - interval '5 month'        as hd_minus_5M,
  4        hiredate + interval '5 month'       as hd_plus_5M,
  5        hiredate - interval '5 year'  as hd_minus_5Y,
  6        hiredate + interval '5 year'         as hd_plus_5Y
  7   from emp
  8  where deptno=10
  MySQL
  同时使用标准加减与INTERVAL关键字,INTERVAL指定时间单位。它不同于PostgreSQL解决方案,不必在INTERVAL值周围加单引号:
  1 select hiredate - interval 5 day               as hd_minus_5D,
  2        hiredate + interval 5 day                 as hd_plus_5D,
  3        hiredate - interval 5 month         as hd_minus_5M,
  4        hiredate + interval 5 month               as hd_plus_5M,
  5        hiredate - interval 5 year           as hd_minus_5Y,
  6        hiredate + interval 5 year          as hd_plus_5Y
  7   from emp
  8  where deptno=10
  另外,也可以使用DATE_ADD函数,如下所示:
  1 select date_add(hiredate,interval -5 day)        as hd_minus_5D,
  2        date_add(hiredate,interval  5 day)          as hd_plus_5D,
  3        date_add(hiredate,interval -5 month) as hd_minus_5M,
  4        date_add(hiredate,interval  5 month)       as hd_plus_5M,
  5        date_add(hiredate,interval -5 year)    as hd_minus_5Y,
  6        date_add(hiredate,interval  5 year)  as hd_plus_5DY
  7  from emp
  8  where deptno=10
  SQL Server
  使用DATEADD函数,可以对日期进行不同时间单位的加减操作:
  1 select dateadd(day,-5,hiredate)        as hd_minus_5D,
  2        dateadd(day,5,hiredate)                  as hd_plus_5D,
  3        dateadd(month,-5,hiredate)         as hd_minus_5M,
  4        dateadd(month,5,hiredate)                as hd_plus_5M,
  5        dateadd(year,-5,hiredate)           as hd_minus_5Y,
  6        dateadd(year,5,hiredate)            as hd_plus_5Y
  7   from emp
  8  where deptno = 10
  讨论
  当进行日期运算时,Oracle解决方案采用整型值表示天数。然而,这种方法只能用来对DATE类型进行运 算。Oracle9i Database引入了TIMESTAMP类型,对这种类型的值应该使用PostgreSQL 给出的INTERVAL解决方案;还要注意,不要把TIMESTAMP传递给老版本的日期函数,如ADD_MONTHS,因为这样做会丢失 TIMESTAMP值可能包含的小数部分。
  INTERVAL 关键字以及与它一起使用的字符串符合ISO标准的SQL语法,该标准要求间隔时间单位用单引号括起来。PostgreSQL(以及Oracle9i Database,或更高版本)遵从此标准。但由于MySQL不支持引号,因此在某种程度上它没有遵从此标准。

运维网声明 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-303596-1-1.html 上篇帖子: mojoPortal在codeplex上的站点 下篇帖子: Postgres远程访问配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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