Heim >Datenbank >MySQL-Tutorial >Warum schlägt meine Postgres 9.1-Fremdschlüsselreferenz mit einem „Unique Constraint'-Fehler fehl?
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!