Если у вас встроенная функция, вы должны поместить определение в файл заголовка.
Это должно сработать (или что-то близкое):
select table_name
from all_constraints
where constraint_type='R'
and r_constraint_name in
(select constraint_name
from all_constraints
where constraint_type in ('P','U')
and table_name='<your table here>');
Следующее утверждение должно дать детям и всем их потомкам. Я проверил это на базе данных Oracle 10.
SELECT level, main.table_name parent,
link.table_name child
FROM user_constraints main, user_constraints link
WHERE main.constraint_type IN ('P', 'U')
AND link.r_constraint_name = main.constraint_name
START WITH main.table_name LIKE UPPER('&&table_name')
CONNECT BY main.table_name = PRIOR link.table_name
ORDER BY level, main.table_name, link.table_name
Вот как можно сделать запрос Майка на один шаг дальше, чтобы получить имена столбцов из имен ограничений:
select * from user_cons_columns
where constraint_name in (
select constraint_name
from all_constraints
where constraint_type='R'
and r_constraint_name in
(select constraint_name
from all_constraints
where constraint_type in ('P','U')
and table_name='<your table name here>'));
select distinct table_name, constraint_name, column_name, r_table_name, position, constraint_type
from (
SELECT uc.table_name,
uc.constraint_name,
cols.column_name,
(select table_name from user_constraints where constraint_name = uc.r_constraint_name)
r_table_name,
(select column_name from user_cons_columns where constraint_name = uc.r_constraint_name and position = cols.position)
r_column_name,
cols.position,
uc.constraint_type
FROM user_constraints uc
inner join user_cons_columns cols on uc.constraint_name = cols.constraint_name
where constraint_type != 'C'
)
start with table_name = '&&tableName' and column_name = '&&columnName'
connect by nocycle
prior table_name = r_table_name
and prior column_name = r_column_name;
Загрузите справочное руководство по Oracle для 10G, в котором приведены таблицы словаря данных.
Ответы выше хороши, но посмотрите другие таблицы, которые могут быть связаны с ограничениями.
SELECT * FROM DICT WHERE TABLE_NAME LIKE '%CONS%';
Наконец, получите инструмент, такой как Toad или SQL Developer, который позволяет вам просматривать этот материал в пользовательском интерфейсе, вам нужно научиться использовать таблицы, но вы также должны использовать пользовательский интерфейс.
свяжитесь с Онлайн-документация Базы данных Oracle
, можно хотеть исследовать представления Словаря Данных . У них есть префиксы:
:
select * from dictionary where table_name like 'ALL%'
<час> пример Продолжающего Mike's, можно хотеть генерировать сценарии для позволения/запрещения ограничений. Я только изменил 'выбор' в первой строке.
select 'alter table ' || TABLE_NAME || ' disable constraint ' || CONSTRAINT_NAME || ';'
from all_constraints
where constraint_type='R'
and r_constraint_name in
(select constraint_name
from all_constraints
where constraint_type in ('P','U')
and table_name='<your table here>');