Heim >Datenbank >MySQL-Tutorial >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
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.
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. orders
和order_items
。order_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
表中的记录也会被自动删除。
具体代码示例如下:
ALTER TABLE order_items DROP FOREIGN KEY fk_order_items_order_id;
上面的代码中,我们使用ALTER TABLE
语句来删除order_items
表中对orders
表的外键约束。
接下来,我们可以执行删除操作,如下所示:
DELETE FROM orders WHERE id = 1;
在执行上面的删除语句时,MySQL将不再验证与被删除行相关的外键约束,从而成功删除父行。
具体代码示例如下:
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
rrreee
Im obigen Code setzen wir das Feldorder_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.
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 AnweisungALTER 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. 🎜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!