绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
oracle中减一个月,EsgynDB add_months函数每月后一天的减运算
2022-07-06 16:59:48

2020年10月有31天,2020年11月有30天,当在2020年11月30日做减一个月的运算时,普通数据库,按照11月30日是改月后一天,减去一个月的值为10月31日,EsgynDB减去一个月不同的写法有不同的结果,更能满足客户不同场景的需求;

oracle:

SQL> select add_months(date '2020-11-30',-1) from dual;

ADD_MONTHS(DATE'20

------------------

31-OCT-20

SQL>

EsgynDB:

SQL2和SQL3的第三个参数可以设置为1或者0:

参数为1时减一个月定位到上月的后一天;

参数为0时减一个月定位到上月与本月同日期的一天,即SQL1与SQL3的结果相同

SQL>select add_months(date '2020-11-30',-1) from dual;  ## SQL1

(EXPR)

----------

2020-10-30

--- 1 row(s) selected.

SQL>select add_months(last_day(date '2020-11-30'),-1,1) from dual;  ## SQL2

(EXPR)

----------

2020-10-31

--- 1 row(s) selected.

SQL>select add_months(last_day(date '2020-11-30'),-1,0) from dual;  ## SQL3

(EXPR)

----------

2020-10-30

--- 1 row(s) selected.

分享好友

分享这个小栈给你的朋友们,一起进步吧。

EsgynDB
创建时间:2022-03-30 10:10:17
EsgynDB
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

技术专家

查看更多
  • itt0918
    专家
戳我,来吐槽~