So deaktivieren Sie die Überprüfung auf Fremdschlüsseleinschränkungen in untergeordneten MySQL-Tabellen

So deaktivieren Sie die Überprüfung auf Fremdschlüsseleinschränkungen in untergeordneten MySQL-Tabellen

Vorbereiten:

Definieren Sie eine Lehrertabelle und eine Schülertabelle. Verweisen Sie in der Schülertabelle auf die Lehrertabellen-ID.

Tabelle Lehrer erstellen (TeacherID Int ungleich NULL, Auto_Increment-Primärschlüssel, Lehrername varchar (8));

Tabelle „Studenten“ erstellen (Studenten-ID int nicht null, auto_increment, Primärschlüssel, Lehrer-ID int nicht null, Studentenname varchar (8),

Einschränkung fk_students_teacherID, Fremdschlüssel (teacherId) verweist auf Lehrer (teacherId) beim Löschen, keine Aktion bei Update-Kaskade);

Erster Schritt:

Einen Lehrer einfügen

in Lehrer(Lehrername) Werte('NameA') einfügen;

Einen Schüler einfügen:

insert into students(studentName,teacherID) values('NameB',100);--Sie können erkennen, dass es keine solche Lehrer-ID gibt und das Einfügen daher fehlschlägt.

Aber gibt es eine Möglichkeit, unangemessene Daten einzufügen? Es gibt noch einen Weg

Schritt 2:

setze foreign_key_checks = 0; und das war's.

in Studenten einfügen (Studentenname, Lehrer-ID) Werte ('NameB', 100);

Schritt 3:

Auf den Standardwert zurücksetzen, Einschränkungsprüfung für Fremdschlüssel beibehalten.

setze foreign_key_checks = 1;

Zusammenfassen:

Dieser Aufsatz ist sehr chaotisch. Der Hauptpunkt, den ich machen möchte, ist, dass Fremdschlüsseleinschränkungen nutzlos sind, wenn sie auf „foreign_key_checks = 0;“ gesetzt sind. Zu diesem Zeitpunkt können Sie in die untergeordnete Tabelle etwas einfügen, das die Fremdschlüsseleinschränkung verletzt.

Verwenden Sie es nur, wenn es unbedingt notwendig ist.

Der obige Artikel über die MySQL-Methode zur Überprüfung von Fremdschlüsseleinschränkungen zum Schließen untergeordneter Tabellen ist alles, was ich mit Ihnen teilen möchte. Ich hoffe, er kann Ihnen als Referenz dienen. Ich hoffe auch, dass Sie 123WORDPRESS.COM unterstützen werden.

Das könnte Sie auch interessieren:
  • Spezielle Methode zum Hinzufügen von Fremdschlüsseleinschränkungen in MySQL
  • MySQL-Fremdschlüsseleinschränkung (FOREIGN KEY) Fallerklärung
  • Zusammenfassung der MySQL-Fremdschlüsseleinschränkungen und Tabellenbeziehungen
  • Beispielerklärung von MySQL-Fremdschlüsseleinschränkungen
  • Detaillierte Erläuterung der MySQL-Fremdschlüsseleinschränkungen
  • Einführung in die MySQL-Methode zum Löschen von Tabellendaten mit Fremdschlüsseleinschränkungen
  • Einfache Implementierung zum Ignorieren von Fremdschlüsseleinschränkungen beim Löschen von MySQL-Tabellen
  • So erstellen und löschen Sie Fremdschlüsseleinschränkungen in MySQL

<<:  Beispielschritte zum Implementieren von Klassenselektoren und Namensattributselektoren in js

>>:  Detaillierte Einführung in den Nobody-Benutzer und Nologin im Unix/Linux-System

Artikel empfehlen

Sprechen Sie über das Verständnis des CSS-Attributrands

1. Was ist eine Marge? Mit dem Rand wird die Abstä...

Hinweise zum MySQL-Datenbank-Sicherungsprozess

Heute habe ich mir einige Dinge im Zusammenhang m...

CSS3 realisiert den leuchtenden Randeffekt

Wirkung der Operation: html <!-- Dieses Elemen...

Über das Problem der vertikalen Zentrierung von img und span in div

Wie unten dargestellt: XML/HTML-CodeInhalt in die...

So erstellen Sie einen DHCP-Server in Linux

Inhaltsverzeichnis 1. Grundkenntnisse: 2. DHCP-Se...

Implementierungsbeispiel für die Message Board-Funktion von Node.js+Express

Inhaltsverzeichnis Nachrichtenbrett Erforderliche...

Detaillierte Erläuterung der drei Möglichkeiten zum Importieren von CSS-Dateien

Es gibt drei Möglichkeiten, CSS einzuführen: Inli...

Interaktion im Webdesign: Eine kurze Diskussion über Paging-Probleme

Funktion: Zur vorherigen Seite oder zur nächsten ...

Zusammenfassung der Befehle zur Benutzerverwaltung im Linux-System

Benutzer- und Gruppenverwaltung 1. Grundlegende K...

Grafisches Tutorial zur Installation und Konfiguration von MySQL 8.0.17

Dieser Artikel enthält das grafische Tutorial zur...