oracle中减一个月,EsgynDB add_months函数每月后一天的减运算
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.
相关文章