Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Oracle [игнор отключен] [закрыт для гостей] / Как передать параметр в неявный курсор? / 3 сообщений из 3, страница 1 из 1
13.11.2018, 11:05
    #39732279
tem@
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как передать параметр в неявный курсор?
Как передать параметр наименования секции (партицирования) в неявный курсор?
пытаюсь сделать такое, таблица разбита по датам ('01.01.2018', '01.03.2018' и тд) с названиями секций ('T012018', 'T022018'...'T102018' ) , мне нужно
передать в параметре наименование той секции в которой нужно сделать выборку:

Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
DECLARE
    period NVARCHAR2(7);
BEGIN

  period := 'T102018';

    FOR C1_REC IN ( select * from table partition (period) where data_test = 'some')
    LOOP
              DBMS_OUTPUT.PUT_LINE(C1_REC.data_test);
    END LOOP;
END;



И получаю соответственно ошибку
ORA-02149: Specified partition does not exist
...
Рейтинг: 0 / 0
13.11.2018, 11:07
    #39732282
-2-
-2-
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как передать параметр в неявный курсор?
tem@,

передавай значение ключа партиционирования.
...
Рейтинг: 0 / 0
13.11.2018, 12:00
    #39732328
merch
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Как передать параметр в неявный курсор?
tem@,

так открой еще один курсор по dba_objects,


Код: plsql
1.
2.
3.
4.
5.
6.
7.
select 
  subobject_name
from dba_objects
where owner = 'OWNER_NAME'
and object_name = 'TABLE_NAME'
and object_type = 'TABLE PARTITION'
order by timestamp



И в цикле динамически лепи свой внутренний курсор с нужной партицией.

Ну и конструкция "open ... for" тебе в помощь
...
Рейтинг: 0 / 0
Форумы / Oracle [игнор отключен] [закрыт для гостей] / Как передать параметр в неявный курсор? / 3 сообщений из 3, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]