Muszę uzyskać nazwę kolumny klucza podstawowego.
Na wejściu mam tylko nazwę tabeli.
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;
Upewnij się, że „TABLE_NAME” jest zapisane dużymi literami, ponieważ Oracle przechowuje nazwy tabel wielkimi literami.
q
.Taka sama jak odpowiedź z „Richie”, ale nieco bardziej zwięzła.
Zapytanie tylko o ograniczenia użytkownika
Zapytanie dla wszystkich ograniczeń
źródło
user_constraints
naall_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;
(Spowoduje to wyświetlenie klucza podstawowego, a następnie)
(To da ci kolumnę, tutaj PK_XYZ to nazwa klucza podstawowego)
źródło
Wypróbuj ten kod Tutaj utworzyłem tabelę do pobierania kolumny klucza podstawowego w Oracle, która nazywa się test, a następnie zapytanie
źródło
Zapisz następujący skrypt jako coś takiego jak findPK.sql.
Następnie można go wywołać za pomocą
źródło