Динамический цикл в PL / SQL - PullRequest
0 голосов
/ 31 января 2019

В настоящее время я перебираю значения в PL / SQL со следующим:

for c in (select * from example_table where name is not null) loop  
  -- logic  
end loop; 

Я хотел бы заменить оператор SQL на динамический, например:

l_sql := 'select * from example_table where || l_col || is not null';  
for c in (l_sql) loop  
  -- logic  
end loop;  

Это возможно?

С уважением

1 Ответ

0 голосов
/ 31 января 2019

Это невозможно с неявным циклом курсора (выберите внутри for loop).Вы можете использовать обычные OPEN .. FETCH .. LOOP - REFCURSOR с переменной записи tablename%ROWTYPE

DECLARE
t_rec  example_table%ROWTYPE;
l_sql  VARCHAR2(1000);
v_cur SYS_REFCURSOR;
l_col varchar2(32) := 'MY_COLUMN';
BEGIN
  l_sql := 'select * from example_table where '|| l_col || ' is not null';  

OPEN v_cur FOR l_sql;
   LOOP
      FETCH v_cur INTO t_rec; --fetch a row 
         EXIT WHEN v_cur%NOTFOUND;

    -- your logic using t_rec columns.
   END LOOP;
CLOSE v_cur;

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