0

有什么方法可以计算任何一年三个季度的第一天和最后一天。2012 年、2013 年或 2014 年

SELECT ADD_MONTHS(TRUNC(SYSDATE, 'Q'), -3) AS First,
       TRUNC(SYSDATE, 'Q') - 1             AS Last
FROM DUAL

计算当年第一季度。我想计算任何一年的第一季度?

4

4 回答 4

3

您可以执行以下操作:

with q(qtr) as(
  select add_months(
                    DATE '2013-01-01'
                    , (level-1)*3
                    )
    from dual 
  connect by level <= 4
)
select qtr                          as first_day
     , last_day(add_months(qtr, 2)) as last_day
  from q

结果:

FIRST_DAY     LAST_DAY
-----------  -----------
01.01.2013    31.03.2013
01.04.2013    30.06.2013
01.07.2013    30.09.2013
01.10.2013    31.12.2013

SQLFiddle 演示

于 2013-08-31T18:35:27.047 回答
1

这是一种方法

select  to_date('01-JAN-'||to_char(yr), 'DD-MON-YYYY') first_qtr,
   to_date('01-APR-'||to_char(yr), 'DD-MON-YYYY') second_qtr,
   to_date('01-JUL-'||to_char(yr), 'DD-MON-YYYY') third_qtr,
   to_date('01-OCT-'||to_char(yr), 'DD-MON-YYYY') fourth_qtr
   from ( select :year yr from dual )
UNION ALL
select to_date('01-APR-'||to_char(yr), 'DD-MON-YYYY')-1 first_qtr,
   to_date('01-JUL-'||to_char(yr), 'DD-MON-YYYY')-1 second_qtr,
   to_date('01-OCT-'||to_char(yr), 'DD-MON-YYYY')-1 third_qtr,
   to_date('01-JAN-'||to_char(yr+1), 'DD-MON-YYYY')-1 fourth_qtr
   from ( select :year yr from dual )

我使用了绑定变量,因此请根据您的要求进行相应更改。

我对 Oracle 还很陌生,所以其他人可以提供简化的代码。

给定 2009 时的输出如下

FIRST_QTR   SECOND_QTR  THIRD_QTR   FOURTH_QTR
01/01/2009  04/01/2009  07/01/2009  10/01/2009
03/31/2009  06/30/2009  09/30/2009  12/31/2009
于 2013-09-02T08:57:13.950 回答
0

每年一行,每行由年份加上 8 个(=每季度 2 个日期)日期组成:

with params as (
  select
    2012 as start_year,
    2014 as end_year
  from
    dual
)
select
           start_year+ level - 1                          year,
  to_date((start_year+ level - 1) || '0101', 'yyyymmdd')  start_q1,
  to_date((start_year+ level - 1) || '0331', 'yyyymmdd')  end_q1  ,
  to_date((start_year+ level - 1) || '0401', 'yyyymmdd')  start_q2,
  to_date((start_year+ level - 1) || '0630', 'yyyymmdd')  end_q2  ,
  to_date((start_year+ level - 1) || '0701', 'yyyymmdd')  start_q3,
  to_date((start_year+ level - 1) || '0930', 'yyyymmdd')  end_q3  ,
  to_date((start_year+ level - 1) || '1001', 'yyyymmdd')  start_q4,
  to_date((start_year+ level - 1) || '1231', 'yyyymmdd')  end_q4
from
  dual, params
connect by
  start_year + level -1 <= end_year;
于 2015-01-22T06:06:20.790 回答
0

这是一个老问题,但也许这会有所帮助:

WITH y1 AS (
    SELECT LEVEL + 2000 AS the_year
      FROM dual
   CONNECT BY LEVEL <= 20
), q1 AS (
    SELECT LEVEL AS the_quarter
      FROM dual
    CONNECT BY LEVEL <= 4
)
SELECT the_year, the_quarter
     , TO_CHAR(first_day, 'DAY') AS first_dw, first_day
     , TO_CHAR(last_day, 'DAY') AS last_dw, last_day
  FROM (
    SELECT the_year, the_quarter
         , ADD_MONTHS(TO_DATE(the_year, 'YYYY'), 3 * (the_quarter - 1)) AS first_day
         , ADD_MONTHS(TO_DATE(the_year, 'YYYY'), 3 * the_quarter) - 1 AS last_day
      FROM y1, q1
)
于 2015-01-22T04:45:53.937 回答