Maison > base de données > tutoriel mysql > le corps du texte

Comment définir des clés étrangères lors de la création d'une table dans MySQL ?

青灯夜游
Libérer: 2020-10-07 12:15:15
original
23027 Les gens l'ont consulté

Comment définir des clés étrangères lors de la création d'une table MySQL : Dans l'instruction "CREATE TABLE", passez "[CONSTRAINT ] FOREIGN KEY field name [, field name 2,...] RÉFÉRENCES < "Nom de la table principale> Colonne de clé primaire 1 [, colonne de clé primaire 2,...]" paramètre d'instruction.

Comment définir des clés étrangères lors de la création d'une table dans MySQL ?

La contrainte de clé étrangère MySQL (FOREIGN KEY) est un champ spécial de la table, souvent utilisé avec des contraintes de clé primaire. Pour deux tables avec une relation associée, la table où se trouve la clé primaire du champ associé est la table primaire (table parent) et la table où se trouve la clé étrangère est la table secondaire (table enfant).

Définissez les contraintes de clé étrangère lors de la création de la table

Dans l'instruction CREATE TABLE, spécifiez la clé étrangère via le mot-clé FOREIGN KEY, en particulier The Le format de syntaxe est le suivant :

[CONSTRAINT <外键名>] FOREIGN KEY 字段名 [,字段名2,…]
REFERENCES <主表名> 主键列1 [,主键列2,…]
Copier après la connexion

Exemple

Afin d'afficher la relation de clé étrangère entre les tables, cet exemple crée une table de département tb_dept1 dans la base de données test_db. structure Comme indiqué dans le tableau ci-dessous.

字段名称数据类型备注
idINT(11)部门编号
nameVARCHAR(22)部门名称
locationVARCHAR(22)部门位置

L'instruction SQL et les résultats d'exécution de la création de tb_dept1 sont les suivants.

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)
Copier après la connexion

Créez la table de données tb_emp6, et créez une contrainte de clé étrangère sur la table tb_emp6, afin que sa clé deptId soit associée à l'identifiant de clé primaire de la table tb_dept1 en tant que clé étrangère et en cours d'exécution. les résultats sont les suivants.

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)
Copier après la connexion

Une fois l'instruction ci-dessus exécutée avec succès, une contrainte de clé étrangère nommée fk_emp_dept1 est ajoutée à la table tb_emp6. Le nom de la clé étrangère est deptId, qui dépend de l'identifiant de clé primaire de la table tb_dept1.

Remarque : la clé étrangère de la table secondaire doit être liée à la clé primaire de la table primaire, et les types de données de la clé primaire et de la clé étrangère doivent être cohérents. Par exemple, les deux sont de type INT ou les deux sont de type CHAR. Si ces conditions ne sont pas remplies, l'erreur « ERREUR 1005 (HY000) : Impossible de créer la table » se produira lors de la création de la table esclave.

Tutoriel recommandé : Tutoriel vidéo MySQL

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal