gpt4 book ai didi

javascript - 是否有任何 JavaScript 方法可以复制 Oracle 的 ADD_MONTH() 功能

转载 作者:行者123 更新时间:2023-11-30 12:13:02 25 4
gpt4 key购买 nike

1) Oracle 的 ADD_MONTHS(date, 1) 示例:

SELECT ADD_MONTHS('30-Nov-15', 3) FROM dual;

February, 29 2016 00:00:00

2) JavaScript:

var date= new Date("Mon Nov 30 2015 00:00:00"); 
date.setMonth(date.getMonth() + 3);

Tue Mar 01 2016 00:00:00

是否有任何 JavaScript 方法可以复制 Oracle 的 ADD_MONTH() 功能?

最佳答案

如果您想实现与 Oracle 函数中相同的逻辑 - 即对于“较短”的月份您不会在下个月溢出,我想您需要自己做:

伪代码:

 myDay = date.getDate(); // save the date
date.setMonth(date.getMonth() + 3); // add months
myNewDay = date.getDate();
while (myDay != myNewDay & myNewDay <= 3) {
myNewDay = myNewDay -1 // go back one day
date.setDate(myNewDay); // restore the
}

因此,如果您在添加月份后以该月的同一天结束,那么您就准备好了。如果你得到一个月中的不同日期,它将是 1,2 或 3(月份长度的差异);一天天回去,直到月底。

这是我对Oracle算法的认识。 HTH.

关于javascript - 是否有任何 JavaScript 方法可以复制 Oracle 的 ADD_MONTH() 功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33236442/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com