正如标题所述,我正在尝试获取 2 个日期之间的最后几天的月份列表。
例子:
2014-08-15
2014-10-15
预期输出
2014-08-31
2014-09-30
我用来实现此目的的查询如下:
SELECT DISTINCT LAST_DAY(TO_DATE('2014-08-15') - 1 + ROWNUM)
FROM ALL_OBJECTS
WHERE TO_DATE('2014-08-15') - 1 + ROWNUM <= TO_DATE('2014-10-15');
但是我有一种感觉可能有一种更优雅的方式来实现它。
任何输入将不胜感激!
要获得与您相同的结果:
select add_months(LAST_DAY(date'2014-08-15'),level-1)
from dual
connect by add_months(trunc(date'2014-08-15','mm'),level-1)<= date'2014-10-15';
但我认为 2014-10-31 不满足您的条件 - “在 2 个日期之间”。
所以可能它应该是这样的
select add_months(LAST_DAY(date'2014-08-15'),level-1)
from dual
connect by add_months(LAST_DAY(date'2014-08-15'),level-1)<=date'2014-10-15';
或者
select add_months(LAST_DAY(date'2014-08-15'),level-1)
from dual
connect by level<=months_between(date'2014-10-15',date'2014-08-15');
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句