Рекурсивно перечислите список представлений Oracle DBA_DEPENDENCIES - PullRequest
3 голосов
/ 17 октября 2011

Я хотел бы получить список зависимых таблиц (в конечном итоге) данного представления.

Например:

SELECT NAME, TYPE, REFERENCED_NAME, REFERENCED_TYPE
FROM DBA_DEPENDENCIES
WHERE OWNER='FOO'
AND NAME='VIEW_O1'

Результаты:

VIEW_O1 VIEW    TABLE_01    TABLE
VIEW_O1 VIEW    TABLE_02    TABLE
VIEW_O1 VIEW    TABLE_03    TABLE
VIEW_O1 VIEW    VIEW_02     VIEW
VIEW_O1 VIEW    VIEW_03     VIEW

Iхотелось бы, чтобы это выглядело так:

VIEW_O1 VIEW    TABLE_01    TABLE
VIEW_O1 VIEW    TABLE_02    TABLE
VIEW_O1 VIEW    TABLE_03    TABLE
VIEW_O1 VIEW    VIEW_02     VIEW
VIEW_O1 VIEW    VIEW_03     VIEW
VIEW_O2 VIEW    TABLE_03    TABLE
VIEW_O2 VIEW    TABLE_04    TABLE
VIEW_O3 VIEW    TABLE_05    TABLE
VIEW_O3 VIEW    VIEW_04     VIEW
VIEW_O4 VIEW    TABLE_06    TABLE
VIEW_O4 VIEW    TABLE_07    TABLE
VIEW_O4 VIEW    TABLE_08    TABLE

Полагаю, у меня должен быть столбец, в котором указана начальная точка, чтобы я мог сохранить происхождение в группе.

Я пыталсяследующий запрос:

SELECT NAME, TYPE, REFERENCED_NAME, REFERENCED_TYPE
FROM DBA_DEPENDENCIES
WHERE OWNER='FOO'
AND NAME='VIEW_01'
CONNECT BY PRIOR REFERENCED_NAME=NAME

но я получаю сообщение об ошибке «ORA-01436: цикл CONNECT BY в пользовательских данных».Чего мне не хватает?

Ответы [ 2 ]

3 голосов
/ 18 октября 2011

Вы хотите указать ключевое слово NOCYCLE после своего CONNECT BY:

т.е.

SELECT NAME, 
       TYPE, 
       REFERENCED_NAME, 
       REFERENCED_TYPE 
  FROM DBA_DEPENDENCIES 
 WHERE OWNER='FOO' 
   AND NAME='VIEW_01' 
CONNECT BY NOCYCLE
  PRIOR REFERENCED_NAME = NAME;

Подробнее о ключевых словах NOCYCLE и "CONNECT_BY_ISCYCLE" читайте здесь: http://www.dba -oracle.com / t_advanced_sql_connect_by_loop.htm

и здесь: http://download.oracle.com/docs/cd/B19306_01/server.102/b14200/pseudocolumns001.htm

Надеюсь, это поможет ...

РЕДАКТИРОВАТЬ: После комментариев вы пропустилипредложение START WITH.

SELECT NAME, 
       TYPE, 
       REFERENCED_NAME, 
       REFERENCED_TYPE 
  FROM DBA_DEPENDENCIES 
 WHERE OWNER='FOO' 
 START WITH NAME='VIEW_01' 
CONNECT BY NOCYCLE
  PRIOR REFERENCED_NAME = NAME;

BTW, сохраняя условие OWNER = 'FOO', где ограничивает любые зависимости, возвращаемые только объекту FOO, так что вы можете пропустить зависимости из других схем.

Редактировать2: первичный ключ таблицы представления - владелец, имя, таким образом, выбор должен начинаться с обоих и соединяться обоими.Вы можете использовать, где отфильтровать желаемые результаты.

SELECT OWNER, NAME, TYPE,  
   REFERENCED_OWNER,
   REFERENCED_NAME, 
   REFERENCED_TYPE 
FROM DBA_DEPENDENCIES 
-- where referenced_type='TABLE'
START WITH owner = 'FOO' AND NAME='VIEW_01' 
CONNECT BY NOCYCLE
   PRIOR REFERENCED_NAME = NAME
   AND PRIOR REFERENCED_OWNER = OWNER;
0 голосов
/ 05 августа 2015

, как сказал Олли, это то же самое:
Этот запрос разрешает все депы, начиная с MYPROC как корня дерева.

SELECT A.NAME,
   A.TYPE,
   A.REFERENCED_OWNER,
   A.REFERENCED_NAME,
   A.REFERENCED_TYPE,
   A.REFERENCED_LINK_NAME,
   A.SCHEMAID  FROM USER_DEPENDENCIES A
 CONNECT BY PRIOR REFERENCED_NAME = A.NAME
 START WITH A.NAME = 'MYPROC'ORDER BY 1, 2, 3, 4
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...