


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:
INSERT INTO bar (foo_fk, name) VALUES ('alice', 'ams'); INSERT INTO bar (foo_fk, name) VALUES ('bob', 'ams');
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:
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) );
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!

In dem Artikel werden mithilfe der Änderungstabelle von MySQL Tabellen, einschließlich Hinzufügen/Löschen von Spalten, Umbenennung von Tabellen/Spalten und Ändern der Spaltendatentypen, erläutert.

In Artikel werden die Konfiguration der SSL/TLS -Verschlüsselung für MySQL, einschließlich der Erzeugung und Überprüfung von Zertifikaten, erläutert. Das Hauptproblem ist die Verwendung der Sicherheitsauswirkungen von selbstsignierten Zertifikaten. [Charakterzahl: 159]

In Artikel werden Strategien zum Umgang mit großen Datensätzen in MySQL erörtert, einschließlich Partitionierung, Sharding, Indexierung und Abfrageoptimierung.

In Artikel werden beliebte MySQL -GUI -Tools wie MySQL Workbench und PhpMyAdmin beschrieben, die ihre Funktionen und ihre Eignung für Anfänger und fortgeschrittene Benutzer vergleichen. [159 Charaktere]

In dem Artikel werden in MySQL die Ablagerung von Tabellen mithilfe der Drop -Tabellenerklärung erörtert, wobei Vorsichtsmaßnahmen und Risiken betont werden. Es wird hervorgehoben, dass die Aktion ohne Backups, die Detaillierung von Wiederherstellungsmethoden und potenzielle Produktionsumfeldgefahren irreversibel ist.

In Artikeln werden ausländische Schlüssel zur Darstellung von Beziehungen in Datenbanken erörtert, die sich auf Best Practices, Datenintegrität und gemeinsame Fallstricke konzentrieren.

In dem Artikel werden in verschiedenen Datenbanken wie PostgreSQL, MySQL und MongoDB Indizes für JSON -Spalten in verschiedenen Datenbanken erstellt, um die Abfrageleistung zu verbessern. Es erläutert die Syntax und die Vorteile der Indizierung spezifischer JSON -Pfade und listet unterstützte Datenbanksysteme auf.

Artikel erläutert die Sicherung von MySQL gegen SQL-Injektions- und Brute-Force-Angriffe unter Verwendung vorbereiteter Aussagen, Eingabevalidierung und starken Kennwortrichtlinien (159 Zeichen).


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

mPDF
mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),

Dreamweaver Mac
Visuelle Webentwicklungstools