Как получить массив с помощью Oracle SQL-запроса - PullRequest
3 голосов
/ 17 марта 2010

Я хочу отобразить набор результатов Годы между С даты - До даты, используя Oracle SQL на двойной таблице

например

, если я передам - ​​С даты как 01.01.1900 и ДоДата как 1/1/2000

, затем показывается

Только годы

1900
1901
1902
-
-

2000

1 Ответ

6 голосов
/ 17 марта 2010

Этот вопрос состоит из двух частей. Создать диапазон дат довольно просто: просто используйте трюк с CONNECT BY, который я продемонстрировал здесь .

редактировать

Создать список первых новогодних дней довольно просто:

SQL> select add_months(to_date('01-jan-1900'), (level-1)*12) as year
  2  from dual
  3  connect by level <= 101
  4  /

YEAR
---------
01-JAN-00
01-JAN-01
01-JAN-02
...
01-JAN-98
01-JAN-99
01-JAN-00

101 rows selected.

SQL>

Вы просто хотите годы? Ну или используйте to_char(... , 'YYYY') на этом. Или перейдите в погоню и просто сгенерируйте список чисел с 1900 по 2000 год.

Самая хитрая часть вашего запроса - это количество лет. Было бы легче получить дату начала и смещение, а не дату окончания. Во всяком случае ...

SQL> select to_char(add_months(to_date('&&start_date'), (level-1)*12), 'YYYY') as year
  2  from dual
  3  connect by level <= ( to_number(to_char(to_date('&&end_date'), 'yyyy'))
  4                       -to_number(to_char(to_date('&&start_date'), 'yyyy')) ) + 1
  5  /
Enter value for start_date: 01-jan-1900
old   1: select add_months(to_date('&&start_date'), (level-1)*12) as year
new   1: select add_months(to_date('01-jan-1900'), (level-1)*12) as year
Enter value for end_date: 01-jan-2000
old   3: connect by level <= ( to_number(to_char(to_date('&&end_date'), 'yyyy'))
new   3: connect by level <= ( to_number(to_char(to_date('01-jan-2000'), 'yyyy'))
old   4:                      -to_number(to_char(to_date('&&start_date'), 'yyyy')) ) - 1
new   4:                      -to_number(to_char(to_date('01-jan-1900'), 'yyyy')) ) - 1


YEAR
----
1900
1901
1902
...
1998
1999
2000

101 rows selected.

SQL> 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...