Просмотрите все столбцы в таблицах в Oracle - PullRequest
0 голосов
/ 01 сентября 2009

Это вопрос новичка, скорее всего, синтаксический. Но я немного растерялся ...

Мне нужно пройти по всем столбцам во всех таблицах в Oracle, чтобы сгенерировать триггерный скрипт. Этот триггер должен вставить обновляемую строку в таблицу журнала, которая почти совпадает с исходной таблицей. Я думал, что просто обойду все столбцы и просто объединю строки. Довольно легко, но я борюсь с синтаксисом ...

Вот что у меня есть:

DECLARE
   cursor tableNames is
      select table_name
      from user_tables
      where table_name not like '%_A';
    lSql varchar2(3000);
    type t_columnRow is ref cursor;

    v_columns t_columnRow;
begin

FOR tableName in tableNames
LOOP
    open v_columns for select COLUMN_NAME from user_tab_columns where table_name = tableName;

    for columnRow in v_columns LOOP
        DBMS_OUTPUT.PUT_LINE(tableName || '.' || columnRow.COLUMN_NAME);
        -- Here I would just concatenate the strings ....
    END LOOP;

END LOOP;    

End;

Для этого я получаю следующую ошибку:

Error at line 1
ORA-06550: line 14, column 84:
PLS-00382: expression is of wrong type
ORA-06550: line 16, column 22:
PLS-00221: 'V_COLUMNS' is not a procedure or is undefined
ORA-06550: line 16, column 5:
PL/SQL: Statement ignored

Ответы [ 2 ]

2 голосов
/ 01 сентября 2009

Попробуйте это:

BEGIN
    FOR t IN (SELECT table_name FROM user_tables WHERE table_name not like '%_A')
    LOOP
        FOR c IN (SELECT column_name FROM user_tab_columns WHERE table_name = t.table_name)
        LOOP
            DBMS_OUTPUT.PUT_LINE(t.table_name||'.'||c.column_name);
            -- Here I would just concatenate the strings ....
        END LOOP;
    END LOOP;
END;
1 голос
/ 01 сентября 2009

Возможно, вам удастся смириться с чем-то простым:

DECLARE
   cursor tableNames is
      select table_name
      from user_tables
      where table_name not like '%_A';
    lSql varchar2(3000);
begin

FOR tableName in tableNames
LOOP   
    for columnRow in (select COLUMN_NAME from user_tab_columns where table_name = tableName) LOOP
        DBMS_OUTPUT.PUT_LINE(tableName || '.' || columnRow.COLUMN_NAME);
        -- Here I would just concatenate the strings ....
    END LOOP;

END LOOP;    

End;
...