oracle中减一个月,EsgynDB add_months函数每月后一天的减运算

2022-07-06 00:00:00 专区 订阅 参数 减去 一个月

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.

相关文章