Как запросить первичный ключ в Oracle 11g - PullRequest
5 голосов
/ 18 марта 2011

Кто-нибудь знает, как запросить первичный ключ таблицы в Oracle 11g?Я видел аналогичный вопрос для SQL Server, но мне не повезло, пытаясь найти ответы в этой теме.

Спасибо!

Ответы [ 2 ]

10 голосов
/ 18 марта 2011

Как пользователь, которому принадлежит таблица, вы можете сделать:

select constraint_name, status, deferrable, deferred, validated, generated 
from user_constraints 
where constraint_type = 'P' and table_name = 'Table Name'

Обновление: я думаю, что это даст вам то, что вам нужно.

SELECT cols.table_name, cols.column_name, cols.position, cons.status, cons.owner
FROM all_constraints cons, all_cons_columns cols
WHERE cols.table_name = 'Table Name'
AND cons.constraint_type = 'P'
AND cons.constraint_name = cols.constraint_name
AND cons.owner = cols.owner
ORDER BY cols.table_name, cols.position

Вы можете проверить это сайт для более подробной информации.

1 голос
/ 06 декабря 2017
select cols.table_name ||' - '||cols.column_name primary_key fromall_constraints cons, all_cons_columns cols,
user_tables ut
where  cons.constraint_type = 'P'
AND cons.constraint_name = cols.constraint_name
AND cons.owner = cols.owner`enter code here`
and cols.table_name = ut.table_name
order by cols.table_name;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...