Heim  >  Artikel  >  Datenbank  >  So schreiben Sie Fremdschlüsseleinschränkungen in MySQL

So schreiben Sie Fremdschlüsseleinschränkungen in MySQL

王林
王林Original
2020-07-08 11:14:5329760Durchsuche

Methode zum Schreiben von MySQL-Fremdschlüsseleinschränkungen: [[CONSTRAINT ] FOREIGN KEY-Feldname REFERENCES Eine Fremdschlüsseleinschränkung ist ein spezielles Feld einer Tabelle, das häufig zusammen mit einer Primärschlüsseleinschränkung verwendet wird.

So schreiben Sie Fremdschlüsseleinschränkungen in MySQL

Geben Sie in der CREATE TABLE-Anweisung den Fremdschlüssel über das Schlüsselwort FOREIGN KEY an.

(Empfohlenes Lernen: MySQL-Tutorial)

Das spezifische Syntaxformat ist wie folgt:

[CONSTRAINT <外键名>] FOREIGN KEY 字段名 [,字段名2,…]
REFERENCES <主表名> 主键列1 [,主键列2,…]

MySQL-Fremdschlüsseleinschränkung (FOREIGN KEY) ist ein Tabelle Spezielles Feld, das häufig mit Primärschlüsseleinschränkungen verwendet wird.

Bei zwei Tabellen mit einer zugehörigen Beziehung ist die Tabelle, in der sich der Primärschlüssel im zugehörigen Feld befindet, die Haupttabelle (übergeordnete Tabelle) und die Tabelle, in der sich der Fremdschlüssel befindet, die sekundäre Tabelle (untergeordnete Tabelle). Tisch).

Bei der Definition von Fremdschlüsseln müssen folgende Regeln beachtet werden:

  • Die Haupttabelle muss bereits in der Datenbank vorhanden sein oder die Tabelle sein, die gerade erstellt wird. Im letzteren Fall handelt es sich bei der Master-Tabelle und der Slave-Tabelle um dieselbe Tabelle. Eine solche Tabelle wird als selbstreferenzielle Tabelle bezeichnet, und diese Struktur wird als selbstreferenzielle Integrität bezeichnet. Für die Haupttabelle muss ein Primärschlüssel definiert werden.

  • Primärschlüssel dürfen keine Nullwerte enthalten, in Fremdschlüsseln sind jedoch Nullwerte zulässig. Das heißt, solange jeder Nicht-Null-Wert des Fremdschlüssels im angegebenen Primärschlüssel vorkommt, ist der Inhalt des Fremdschlüssels korrekt.

  • Geben Sie den Spaltennamen oder eine Kombination von Spaltennamen nach dem Tabellennamen der Haupttabelle an. Diese Spalte oder Spaltenkombination muss der Primärschlüssel oder Kandidatenschlüssel der Haupttabelle sein.

  • Die Anzahl der Spalten im Fremdschlüssel muss mit der Anzahl der Spalten im Primärschlüssel der Haupttabelle übereinstimmen.

  • Der Datentyp der Spalte im Fremdschlüssel muss mit dem Datentyp der entsprechenden Spalte im Primärschlüssel der Haupttabelle übereinstimmen.

Beispiel:

Um die Fremdschlüsselbeziehung zwischen Tabellen anzuzeigen, erstellt dieses Beispiel eine Abteilungstabelle tb_dept1 in der Datenbank test_db. Die Tabellenstruktur ist wie in gezeigt die folgende Tabelle.

So schreiben Sie Fremdschlüsseleinschränkungen in MySQL

Die SQL-Anweisung und die laufenden Ergebnisse der Erstellung von tb_dept1 lauten wie folgt.

mysql> CREATE TABLE tb_dept1
    -> (
    -> id INT(11) PRIMARY KEY,
    -> name VARCHAR(22) NOT NULL,
    -> location VARCHAR(50)
    -> );
Query OK, 0 rows affected (0.37 sec)

Erstellen Sie die Datentabelle tb_emp6 und erstellen Sie eine Fremdschlüsseleinschränkung für die Tabelle tb_emp6, sodass ihre Schlüssel-Abteilungs-ID mit der Primärschlüssel-ID der Tabelle tb_dept1 als Fremdschlüssel verknüpft ist und ausgeführt wird Die Ergebnisse sind wie folgt.

mysql> CREATE TABLE tb_emp6
    -> (
    -> id INT(11) PRIMARY KEY,
    -> name VARCHAR(25),
    -> deptId INT(11),
    -> salary FLOAT,
    -> CONSTRAINT fk_emp_dept1
    -> FOREIGN KEY(deptId) REFERENCES tb_dept1(id)
    -> );
Query OK, 0 rows affected (0.37 sec)

mysql> DESC tb_emp6;
+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id     | int(11)     | NO   | PRI | NULL    |       |
| name   | varchar(25) | YES  |     | NULL    |       |
| deptId | int(11)     | YES  | MUL | NULL    |       |
| salary | float       | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+
4 rows in set (1.33 sec)

Nachdem die obige Anweisung erfolgreich ausgeführt wurde, wird eine Fremdschlüsseleinschränkung mit dem Namen fk_emp_dept1 zur Tabelle tb_emp6 hinzugefügt. Der Fremdschlüsselname ist deptId, der von der Primärschlüssel-ID der Tabelle tb_dept1 abhängt.

Hinweis: Der Fremdschlüssel der Sekundärtabelle muss mit dem Primärschlüssel der Primärtabelle verknüpft sein und die Datentypen des Primärschlüssels und des Fremdschlüssels müssen konsistent sein. Beispielsweise sind beide vom Typ INT oder beide vom Typ CHAR. Wenn diese Anforderungen nicht erfüllt sind, tritt beim Erstellen der Slave-Tabelle der Fehler „ERROR 1005 (HY000): Tabelle kann nicht erstellt werden“ auf.

Das obige ist der detaillierte Inhalt vonSo schreiben Sie Fremdschlüsseleinschränkungen in MySQL. 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