Heim >Datenbank >MySQL-Tutorial >Warum schlägt meine Postgres 9.1-Fremdschlüsselreferenz mit einem „Unique Constraint'-Fehler fehl?

Warum schlägt meine Postgres 9.1-Fremdschlüsselreferenz mit einem „Unique Constraint'-Fehler fehl?

Patricia Arquette
Patricia ArquetteOriginal
2025-01-08 22:22:45689Durchsuche

Why Does My Postgres 9.1 Foreign Key Reference Fail with a

Behebung des Fehlers „Ungelöste eindeutige Einschränkung“ in PostgreSQL 9.1-Fremdschlüsselreferenzen

Beim Erstellen einer Tabellenstruktur mit Fremdschlüsselreferenzen in PostgreSQL 9.1 können unerwartete Fehler auftreten. Dieser Fehler resultiert aus einer inkonsistenten Einschränkungskonfiguration.

Der betreffende SQL-Code umfasst die Erstellung von drei Tabellen: foo, bar und baz. Die Tabelle „foo“ hat einen Primärschlüssel für die Spalte „name“, während die Tabelle „bar“ die Spalte „foo_fk“ als Fremdschlüssel definiert, der auf „foo(name)“ verweist. In der Fehlermeldung wird jedoch bemängelt, dass die Namensspalte, auf die in der Balkentabelle verwiesen wird, keine Eindeutigkeitsbeschränkung aufweist.

Um dieses Problem zu verstehen, betrachten Sie das Szenario, in dem mehrere Zeilen in der Balkentabelle denselben Namenswert haben, wie im folgenden Beispiel gezeigt:

<code class="language-sql">INSERT INTO bar (foo_fk, name) VALUES ('alice', 'ams');
INSERT INTO bar (foo_fk, name) VALUES ('bob', 'ams');</code>

Wenn wir nun versuchen, eine Zeile in die Baz-Tabelle einzufügen und auf den mehrdeutigen AMS-Wert in der Balkentabelle zu verweisen, kann PostgreSQL die Zielzeile nicht eindeutig identifizieren. Diese Mehrdeutigkeit entsteht, weil PostgreSQL nicht bestimmen kann, auf welche Zeile in der Balkentabelle der Fremdschlüssel verweisen soll.

Die Lösung besteht darin, die Eindeutigkeit der Namensspalte in der Balkentabelle zu erzwingen. Durch das Hinzufügen einer eindeutigen Einschränkung zur Namensspalte stellen wir sicher, dass jede Zeile in der Balkentabelle einen anderen Namenswert hat, wodurch Mehrdeutigkeiten beseitigt werden und PostgreSQL die eindeutige Identifizierung der referenzierten Zeile ermöglicht.

Der korrigierte SQL-Code einschließlich der notwendigen Einschränkungen lautet wie folgt:

<code class="language-sql">CREATE TABLE foo (
    name        VARCHAR(256) PRIMARY KEY
);

CREATE TABLE bar (
    pkey        SERIAL PRIMARY KEY,
    foo_fk      VARCHAR(256) NOT NULL REFERENCES foo(name),
    name        VARCHAR(256) NOT NULL,
    UNIQUE (name)  -- 添加唯一约束
);

CREATE TABLE baz(
    pkey        SERIAL PRIMARY KEY,
    bar_fk      VARCHAR(256) NOT NULL REFERENCES bar(name),
    name        VARCHAR(256)
);</code>

Mit dieser eindeutigen Einschränkung kann PostgreSQL nun erfolgreich die Tabellenstruktur erstellen und den Fehler „Keine eindeutige Einschränkung, die mit dem angegebenen Schlüssel übereinstimmt“ vermeiden.

Das obige ist der detaillierte Inhalt vonWarum schlägt meine Postgres 9.1-Fremdschlüsselreferenz mit einem „Unique Constraint'-Fehler fehl?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn