Maison >base de données >tutoriel mysql >Comment écrire des contraintes de clé étrangère dans MySQL
Méthode d'écriture de contrainte de clé étrangère MySQL : [[CONSTRAINT
] FOREIGN KEY nom du champ REFERENCES Une contrainte de clé étrangère est un champ spécial d'une table qui est souvent utilisé avec une contrainte de clé primaire.
Dans l'instruction CREATE TABLE, spécifiez la clé étrangère via le mot-clé FOREIGN KEY.
(Apprentissage recommandé : tutoriel mysql)
Le format de syntaxe spécifique est le suivant :
[CONSTRAINT <外键名>] FOREIGN KEY 字段名 [,字段名2,…] REFERENCES <主表名> 主键列1 [,主键列2,…]
La contrainte de clé étrangère MySQL (FOREIGN KEY) est une table Champ spécial, 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 principale (table parent), et la table où se trouve la clé étrangère est la table secondaire (table enfant tableau).
Lors de la définition des clés étrangères, les règles suivantes doivent être respectées :
La table principale doit déjà exister dans la base de données, ou être la table en cours de création. Si c'est le dernier cas, la table maître et la table esclave sont la même table. Une telle table est appelée table auto-référentielle, et cette structure est appelée intégrité auto-référentielle. Une clé primaire doit être définie pour la table principale.
Les clés primaires ne peuvent pas contenir de valeurs nulles, mais les valeurs nulles sont autorisées dans les clés étrangères. Autrement dit, tant que chaque valeur non nulle de la clé étrangère apparaît dans la clé primaire spécifiée, le contenu de la clé étrangère est correct.
Spécifiez le nom de colonne ou une combinaison de noms de colonnes après le nom de la table principale. Cette colonne ou combinaison de colonnes doit être la clé primaire ou la clé candidate de la table primaire.
Le nombre de colonnes dans la clé étrangère doit être le même que le nombre de colonnes dans la clé primaire de la table principale.
Le type de données de la colonne dans la clé étrangère doit être le même que le type de données de la colonne correspondante dans la clé primaire de la table principale.
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. La structure de la table est celle indiquée dans. le tableau suivant.
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)
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)
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.
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!