Мне нужно получить имя столбца первичного ключа.
На входе у меня только имя таблицы.
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;
Убедитесь, что «TABLE_NAME» написана в верхнем регистре, поскольку Oracle хранит имена таблиц в верхнем регистре.
q
.То же, что и ответ «Ричи», но немного более кратко.
Запрос только для ограничений пользователя
Запрос на все ограничения
источник
user_constraints
наall_constraints
.SELECT owner, column_name, position FROM all_cons_columns WHERE (owner, constraint_name) in (SELECT owner, constraint_name FROM all_constraints WHERE UPPER(table_name) = UPPER('&tableName') AND CONSTRAINT_TYPE = 'P') order by owner, position;
(Это будет список первичного ключа, а затем)
(Это даст вам столбец, здесь PK_XYZ - это имя первичного ключа)
источник
Попробуйте этот код Здесь я создал таблицу для получения столбца первичного ключа в Oracle, который называется тестом, а затем запросом
источник
Сохраните следующий сценарий как что-то вроде findPK.sql.
Затем его можно вызвать с помощью
источник