


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
Oct 05, 2023 am 08:49 AMSo 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.
- 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. 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
表中的记录也会被自动删除。
- 解除外键约束后删除
如果我们不希望设置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将不再验证与被删除行相关的外键约束,从而成功删除父行。
- 更新父行的值
在某些情况下,我们可能只想更新父行的值而不是删除它。在这种情况下,我们需要先更新与该父行相关的所有子行的外键引用,然后再更新父行的值。
具体代码示例如下:
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.
- 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 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. 🎜- 🎜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!

Heißer Artikel

Hot-Tools-Tags

Heißer Artikel

Heiße Artikel -Tags

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

PHPs Fähigkeiten zur Verarbeitung von Big-Data-Strukturen

Wie optimiert man die MySQL-Abfrageleistung in PHP?

Wie verwende ich MySQL-Backup und -Wiederherstellung in PHP?

Wie füge ich mit PHP Daten in eine MySQL-Tabelle ein?

Welche Anwendungsszenarien gibt es für Java-Aufzählungstypen in Datenbanken?

So beheben Sie den Fehler „mysql_native_password nicht geladen' unter MySQL 8.4

Wie verwende ich gespeicherte MySQL-Prozeduren in PHP?

Strategien zur Leistungsoptimierung für PHP-Array-Paging
