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
Freigeben: 2025-01-08 22:22:45
Original
740 Leute haben es durchsucht

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage