Heim  >  Artikel  >  Datenbank  >  Eine ü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

Eine ü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

WBOY
WBOYOriginal
2023-10-05 08:49:141907Durchsuche

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