Ich habe dieses Schema zu erhalten:Postgresql Abfrage Fremdschlüssel mehrspaltigen
create table "cat" (
"name" varchar(64),
"owner" varchar(64),
primary key ("name", "owner")
);
create table "comment" (
"name" varchar(45),
"owner" varchar(45),
"id" uuid,
"comment" text,
primary key ("id"),
foreign key ("name", "owner") references "cat"("name", "owner")
);
Ich möchte, um eine Liste von Fremdschlüsseln aus der Tabelle „Kommentar“ zu „cat“, so verwende ich:
SELECT
tc.constraint_name, tc.table_name, kcu.column_name,
ccu.table_name AS foreign_table_name,
ccu.column_name AS foreign_column_name
FROM
information_schema.table_constraints AS tc
JOIN information_schema.key_column_usage AS kcu
ON tc.constraint_name = kcu.constraint_name
JOIN information_schema.constraint_column_usage AS ccu
ON ccu.constraint_name = tc.constraint_name
WHERE constraint_type = 'FOREIGN KEY'
;
und bekam fast, was ich will:
constraint_name | table_name | column_name | foreign_table_name | foreign_column_name
-------------------+------------+-------------+--------------------+---------------------
comment_name_fkey | comment | owner | cat | name
comment_name_fkey | comment | name | cat | name
comment_name_fkey | comment | owner | cat | owner
comment_name_fkey | comment | name | cat | owner
Aber es gibt Zeile 1 und Zeile 4, die ich mag würde im Ergebnis beseitigen, weil es nicht mi tut Richten Sie die Abhängigkeiten der Spalte aus. Wie kann ich es in Postgresql machen?