suchen
HeimDatenbankMySQL-TutorialEine übergeordnete Zeile kann nicht gelöscht oder aktualisiert werden: Eine Fremdschlüsseleinschränkung schlägt fehl – ​​So beheben Sie den MySQL-Fehler: Die übergeordnete Zeile weist eine Fremdschlüsseleinschränkung auf

Cannot delete or update a parent row: a foreign key constraint fails - 如何解决MySQL报错:父行有外键约束

So beheben Sie den MySQL-Fehler: Die übergeordnete Zeile weist Fremdschlüsseleinschränkungen auf. Es sind spezifische Codebeispiele erforderlich.

Bei der Entwicklung mit einer MySQL-Datenbank wird häufig eine Fehlermeldung angezeigt: „Eine übergeordnete Zeile kann nicht gelöscht oder aktualisiert werden: ein Fremdschlüssel.“ Einschränkung schlägt fehl“ (Übergeordnete Zeile kann nicht gelöscht oder aktualisiert werden: Fremdschlüsseleinschränkung vorhanden).

Diese Fehlermeldung erscheint normalerweise, wenn wir versuchen, eine Zeile zu löschen oder zu aktualisieren, auf die Datensätze in anderen Tabellen verweisen. In diesem Fall verhindert MySQL den Lösch- oder Aktualisierungsvorgang für die übergeordnete Zeile basierend auf der Fremdschlüsseleinschränkung. Um dieses Problem zu lösen, müssen wir Fremdschlüsseleinschränkungen entsprechend behandeln.

Im Folgenden finden Sie einige Methoden zur Lösung dieses Problems mit spezifischen Codebeispielen.

  1. Löschen Sie zugehörige untergeordnete Zeilendaten
    Bevor wir einen Lösch- oder Aktualisierungsvorgang durchführen, müssen wir die untergeordneten Zeilendaten löschen, die sich auf die übergeordnete Zeile beziehen. Dies kann durch Setzen des ON DELETE CASCADE-Attributs des Fremdschlüssels erreicht werden. Wenn eine übergeordnete Zeile gelöscht wird, werden auch alle untergeordneten Zeilen, die auf die übergeordnete Zeile verweisen, automatisch gelöscht.

Angenommen, wir haben zwei Tabellen: orders und order_items. Das Feld order_id der Tabelle order_items ist ein Fremdschlüsselverweis auf die Bestellung in der Tabelle orders. Wenn wir eine Bestellung in der Tabelle orders löschen möchten, müssen wir zunächst die mit der Bestellung verbundenen Unterzeilendaten in der Tabelle order_items löschen. ordersorder_itemsorder_items表的order_id字段是对orders表中订单的外键引用。当我们要删除orders表中的某个订单时,必须先删除order_items表中与该订单相关的子行数据。

具体代码示例如下:

CREATE TABLE orders(
    id INT PRIMARY KEY,
    order_name VARCHAR(50)
);

CREATE TABLE order_items(
    id INT PRIMARY KEY,
    order_id INT,
    item_name VARCHAR(50),
    FOREIGN KEY (order_id) REFERENCES orders(id) ON DELETE CASCADE
);

在上面的代码中,我们在创建order_items表时将order_id字段设置为对orders表的外键约束,并指定了ON DELETE CASCADE。这样,当我们删除orders表中的某个订单时,与该订单相关的order_items表中的记录也会被自动删除。

  1. 解除外键约束后删除
    如果我们不希望设置ON DELETE CASCADE,或者无法删除与父行相关的子行数据,我们可以先解除外键约束,然后再进行删除操作。

具体代码示例如下:

ALTER TABLE order_items DROP FOREIGN KEY fk_order_items_order_id;

上面的代码中,我们使用ALTER TABLE语句来删除order_items表中对orders表的外键约束。

接下来,我们可以执行删除操作,如下所示:

DELETE FROM orders WHERE id = 1;

在执行上面的删除语句时,MySQL将不再验证与被删除行相关的外键约束,从而成功删除父行。

  1. 更新父行的值
    在某些情况下,我们可能只想更新父行的值而不是删除它。在这种情况下,我们需要先更新与该父行相关的所有子行的外键引用,然后再更新父行的值。

具体代码示例如下:

UPDATE order_items SET order_id = 2 WHERE order_id = 1;
UPDATE orders SET id = 2 WHERE id = 1;

在上面的代码中,我们首先更新order_items表中的外键引用,将之前引用父行ID为1的记录的order_id字段值更新为2。然后,我们再更新orders

Das spezifische Codebeispiel lautet wie folgt:

rrreee

Im obigen Code setzen wir das Feld order_id auf orders, wenn wir die order_items erstellen Tabelle: Fremdschlüsseleinschränkungen für die Tabelle, und ON DELETE CASCADE ist angegeben. Wenn wir auf diese Weise eine Bestellung in der Tabelle orders löschen, werden auch die mit der Bestellung verbundenen Datensätze in der Tabelle order_items automatisch gelöscht.

    Nach dem Aufheben der Fremdschlüsseleinschränkung löschen

    Wenn wir ON DELETE CASCADE nicht festlegen möchten oder die Daten der untergeordneten Zeile, die sich auf die übergeordnete Zeile beziehen, nicht löschen können, können wir zuerst die Fremdschlüsseleinschränkung aufheben und dann löschen.

    🎜🎜Das spezifische Codebeispiel lautet wie folgt: 🎜rrreee🎜Im obigen Code verwenden wir die Anweisung ALTER TABLE, um die Tabelle orders in den order_items zu löschen Tabellenfremdschlüsseleinschränkungen. 🎜🎜Als nächstes können wir einen Löschvorgang wie unten gezeigt durchführen: 🎜rrreee🎜 Wenn Sie die obige Löschanweisung ausführen, validiert MySQL die Fremdschlüsseleinschränkungen im Zusammenhang mit der gelöschten Zeile nicht mehr und löscht somit die übergeordnete Zeile erfolgreich. 🎜
      🎜Aktualisieren Sie den Wert der übergeordneten Zeile🎜In manchen Fällen möchten wir möglicherweise nur den Wert der übergeordneten Zeile aktualisieren, anstatt ihn zu löschen. In diesem Fall müssen wir die Fremdschlüsselreferenzen aller untergeordneten Zeilen aktualisieren, die sich auf diese übergeordnete Zeile beziehen, bevor wir den Wert der übergeordneten Zeile aktualisieren. 🎜🎜🎜Das spezifische Codebeispiel lautet wie folgt: 🎜rrreee🎜Im obigen Code aktualisieren wir zunächst die Fremdschlüsselreferenz in der Tabelle order_items auf die order_id, die zuvor auf den Datensatz verwiesen hat, dessen übergeordnetes Element Zeilen-ID ist 1 Der Feldwert wird auf 2 aktualisiert. Anschließend aktualisieren wir den Wert des Datensatzes mit der ID 1 in der Tabelle orders auf 2. 🎜🎜Auf diese Weise haben wir den Wert der übergeordneten Zeile erfolgreich aktualisiert. 🎜🎜Zusammenfassung: 🎜🎜Wenn der MySQL-Fehler auftritt: „Eine übergeordnete Zeile kann nicht gelöscht oder aktualisiert werden: Eine Fremdschlüsseleinschränkung schlägt fehl“, können wir die Daten der untergeordneten Zeile, die sich auf die übergeordnete Zeile beziehen, löschen oder aktualisieren, indem wir den Wert der Fremdschlüsseleinschränkung löschen die übergeordnete Zeile, um dieses Problem zu lösen. Wählen Sie die entsprechende Verarbeitungsmethode entsprechend den spezifischen Geschäftsanforderungen und Datenbetriebsbedingungen aus und schreiben Sie angemessenen Code, um das Problem der Fremdschlüsseleinschränkungen zu lösen. 🎜

Das obige ist der detaillierte Inhalt vonEine übergeordnete Zeile kann nicht gelöscht oder aktualisiert werden: Eine Fremdschlüsseleinschränkung schlägt fehl – ​​So beheben Sie den MySQL-Fehler: Die übergeordnete Zeile weist eine Fremdschlüsseleinschränkung auf. 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
Mysqls Platz: Datenbanken und ProgrammierungMysqls Platz: Datenbanken und ProgrammierungApr 13, 2025 am 12:18 AM

Die Position von MySQL in Datenbanken und Programmierung ist sehr wichtig. Es handelt sich um ein Open -Source -Verwaltungssystem für relationale Datenbankverwaltung, das in verschiedenen Anwendungsszenarien häufig verwendet wird. 1) MySQL bietet effiziente Datenspeicher-, Organisations- und Abruffunktionen und unterstützt Systeme für Web-, Mobil- und Unternehmensebene. 2) Es verwendet eine Client-Server-Architektur, unterstützt mehrere Speichermotoren und Indexoptimierung. 3) Zu den grundlegenden Verwendungen gehören das Erstellen von Tabellen und das Einfügen von Daten, und erweiterte Verwendungen beinhalten Multi-Table-Verknüpfungen und komplexe Abfragen. 4) Häufig gestellte Fragen wie SQL -Syntaxfehler und Leistungsprobleme können durch den Befehl erklären und langsam abfragen. 5) Die Leistungsoptimierungsmethoden umfassen die rationale Verwendung von Indizes, eine optimierte Abfrage und die Verwendung von Caches. Zu den Best Practices gehört die Verwendung von Transaktionen und vorbereiteten Staten

MySQL: Von kleinen Unternehmen bis zu großen UnternehmenMySQL: Von kleinen Unternehmen bis zu großen UnternehmenApr 13, 2025 am 12:17 AM

MySQL ist für kleine und große Unternehmen geeignet. 1) Kleinunternehmen können MySQL für das grundlegende Datenmanagement verwenden, z. B. das Speichern von Kundeninformationen. 2) Große Unternehmen können MySQL verwenden, um massive Daten und komplexe Geschäftslogik zu verarbeiten, um die Abfrageleistung und die Transaktionsverarbeitung zu optimieren.

Was liest Phantom und wie verhindert InnoDB sie (Sperren des nächsten Schlägers)?Was liest Phantom und wie verhindert InnoDB sie (Sperren des nächsten Schlägers)?Apr 13, 2025 am 12:16 AM

InnoDB verhindert effektiv das Phantom-Lesen durch den Mechanismus für den nächsten Kleien. 1) Nächstschlüsselmesser kombiniert Zeilensperr- und Gap-Sperre, um Datensätze und deren Lücken zu sperren, um zu verhindern, dass neue Datensätze eingefügt werden. 2) In praktischen Anwendungen kann durch Optimierung der Abfragen und Anpassung der Isolationsstufen die Verringerungswettbewerb reduziert und die Gleichzeitleistung verbessert werden.

MySQL: Keine Programmiersprache, sondern ...MySQL: Keine Programmiersprache, sondern ...Apr 13, 2025 am 12:03 AM

MySQL ist keine Programmiersprache, aber seine Abfragesprache SQL hat die Eigenschaften einer Programmiersprache: 1. SQL unterstützt bedingte Beurteilung, Schleifen und variable Operationen; 2. Durch gespeicherte Prozeduren, Auslöser und Funktionen können Benutzer komplexe logische Operationen in der Datenbank ausführen.

MySQL: Eine Einführung in die beliebteste Datenbank der WeltMySQL: Eine Einführung in die beliebteste Datenbank der WeltApr 12, 2025 am 12:18 AM

MySQL ist ein Open Source Relational Database Management -System, das hauptsächlich zum schnellen und zuverlässigen Speicher und Abrufen von Daten verwendet wird. Sein Arbeitsprinzip umfasst Kundenanfragen, Abfragebedingungen, Ausführung von Abfragen und Rückgabergebnissen. Beispiele für die Nutzung sind das Erstellen von Tabellen, das Einsetzen und Abfragen von Daten sowie erweiterte Funktionen wie Join -Operationen. Häufige Fehler umfassen SQL -Syntax, Datentypen und Berechtigungen sowie Optimierungsvorschläge umfassen die Verwendung von Indizes, optimierte Abfragen und die Partitionierung von Tabellen.

Die Bedeutung von MySQL: Datenspeicherung und -verwaltungDie Bedeutung von MySQL: Datenspeicherung und -verwaltungApr 12, 2025 am 12:18 AM

MySQL ist ein Open Source Relational Database Management -System, das für Datenspeicher, Verwaltung, Abfrage und Sicherheit geeignet ist. 1. Es unterstützt eine Vielzahl von Betriebssystemen und wird in Webanwendungen und anderen Feldern häufig verwendet. 2. Durch die Client-Server-Architektur und verschiedene Speichermotoren verarbeitet MySQL Daten effizient. 3. Die grundlegende Verwendung umfasst das Erstellen von Datenbanken und Tabellen, das Einfügen, Abfragen und Aktualisieren von Daten. 4. Fortgeschrittene Verwendung beinhaltet komplexe Abfragen und gespeicherte Verfahren. 5. Häufige Fehler können durch die Erklärungserklärung debuggen. 6. Die Leistungsoptimierung umfasst die rationale Verwendung von Indizes und optimierte Abfrageanweisungen.

Warum MySQL verwenden? Vorteile und VorteileWarum MySQL verwenden? Vorteile und VorteileApr 12, 2025 am 12:17 AM

MySQL wird für seine Leistung, Zuverlässigkeit, Benutzerfreundlichkeit und Unterstützung der Gemeinschaft ausgewählt. 1.MYSQL bietet effiziente Datenspeicher- und Abruffunktionen, die mehrere Datentypen und erweiterte Abfragevorgänge unterstützen. 2. Übernehmen Sie die Architektur der Client-Server und mehrere Speichermotoren, um die Transaktion und die Abfrageoptimierung zu unterstützen. 3. Einfach zu bedienend unterstützt eine Vielzahl von Betriebssystemen und Programmiersprachen. V.

Beschreiben Sie InnoDB-Verriegelungsmechanismen (gemeinsame Schlösser, exklusive Schlösser, Absichtssperrungen, Aufzeichnungsschlösser, Lückensperrungen, Sperren der nächsten Schlüsse).Beschreiben Sie InnoDB-Verriegelungsmechanismen (gemeinsame Schlösser, exklusive Schlösser, Absichtssperrungen, Aufzeichnungsschlösser, Lückensperrungen, Sperren der nächsten Schlüsse).Apr 12, 2025 am 12:16 AM

Zu den Verriegelungsmechanismen von InnoDB gehören gemeinsame Schlösser, exklusive Schlösser, Absichtsschlösser, Aufzeichnungsschlösser, Lückensperrungen und nächste Schlüsselschlösser. 1. Shared Lock ermöglicht es Transaktionen, Daten zu lesen, ohne dass andere Transaktionen lesen. 2. Exklusives Schloss verhindert, dass andere Transaktionen Daten lesen und ändern. 3.. Intention Lock optimiert die Sperreffizienz. 4. Rekord -Sperr -Indexdatensatz. 5. Gap Lock Locks Index -Aufzeichnungslücke. 6. Die nächste Schlüsselsperrung ist eine Kombination aus Datensatzsperr- und Lückensperrung, um die Datenkonsistenz zu gewährleisten.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

MantisBT

MantisBT

Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Leistungsstarke integrierte PHP-Entwicklungsumgebung

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung