Maison > base de données > tutoriel mysql > Comment ajouter des clés étrangères dans MySQL

Comment ajouter des clés étrangères dans MySQL

(*-*)浩
Libérer: 2020-09-16 18:00:20
original
25972 Les gens l'ont consulté

Comment ajouter des clés étrangères dans MySQL : 1. Dans l'instruction CREATE TABLE, ajoutez des clés étrangères via le mot-clé FOREIGN KEY ; 2. Dans l'instruction ALTER TABLE, ajoutez des clés étrangères via les mots-clés ADD et FOREIGN KEY.

Comment ajouter des clés étrangères dans MySQL

Cours recommandé : Tutoriel 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).

Les clés étrangères sont utilisées pour établir la relation entre la table maître et la table esclave, établir une connexion pour les données des deux tables et contraindre la cohérence et l'intégrité des données dans les deux tables. Par exemple, un étal de fruits ne propose que quatre sortes de fruits : des pommes, des pêches, des prunes et des pastèques. Ensuite, lorsque vous venez à l'étal de fruits pour acheter des fruits, vous ne pouvez choisir que des pommes, des pêches, des prunes et des pastèques. ne sont pas disponibles à l’achat.

Lorsqu'un enregistrement est supprimé de la table principale, l'enregistrement correspondant de la table doit également être modifié en conséquence. Une table peut avoir une ou plusieurs clés étrangères, et la clé étrangère peut être nulle. Si elle n'est pas nulle, la valeur de chaque clé étrangère doit être égale à une certaine valeur de la clé primaire de la table principale.

Lors de la définition des clés étrangères, vous devez respecter les règles suivantes :

  • 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.

  • Doit définir une clé primaire 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 principale.

  • 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.

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

Dans l'instruction CREATE TABLE, utilisez le mot-clé FOREIGN KEY Specify la clé étrangère. Le format de syntaxe spécifique est le suivant :

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

Exemple 1

Afin de montrer la relation de clé étrangère entre les tables, cet exemple est créé dans le base de données test_db Une table de département tb_dept1, la structure de la table est présentée dans le tableau suivant.

Comment ajouter des clés étrangères dans MySQL

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.

Ajouter des contraintes de clé étrangère lors de la modification de la table

Des contraintes de clé étrangère peuvent également être ajoutées lors de la modification de la table, mais l'ajout de clés Le principe de la contrainte est le suivant : les données de la colonne de clé étrangère de la table secondaire doivent être cohérentes avec les données de la colonne de clé primaire de la table primaire, sinon il n'y a pas de données.

Le format de syntaxe pour ajouter des contraintes de clé étrangère lors de la modification de la table de données est le suivant :

ALTER TABLE <数据表名> ADD CONSTRAINT <外键名>
FOREIGN KEY(<列名>) REFERENCES <主表名> (<列名>);
Copier après la connexion

Exemple 2

Modifier la table de données tb_emp2, définir le champ deptId comme clé étrangère et faire correspondre les données. L'identifiant de clé primaire de la table tb_dept1 est associé. L'instruction SQL et les résultats d'exécution sont les suivants.

mysql> ALTER TABLE tb_emp2
    -> ADD CONSTRAINT fk_tb_dept1
    -> FOREIGN KEY(deptId)
    -> REFERENCES tb_dept1(id);
Query OK, 0 rows affected (1.38 sec)
Records: 0  Duplicates: 0  Warnings: 0
mysql> SHOW CREATE TABLE tb_emp2\G
*************************** 1. row ***************************
       Table: tb_emp2
Create Table: CREATE TABLE `tb_emp2` (
  `id` int(11) NOT NULL,
  `name` varchar(30) DEFAULT NULL,
  `deptId` int(11) DEFAULT NULL,
  `salary` float DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `fk_tb_dept1` (`deptId`),
  CONSTRAINT `fk_tb_dept1` FOREIGN KEY (`deptId`) REFERENCES `tb_dept1` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=gb2312
1 row in set (0.12 sec)
Copier après la connexion

Remarque : lors de l'ajout de contraintes de clé étrangère à la table de données créée, assurez-vous que les valeurs des colonnes auxquelles les contraintes de clé étrangère sont ajoutées proviennent toutes des colonnes de clé primaire, et la clé étrangère les colonnes ne peuvent pas être vides.

Supprimer les contraintes de clé étrangère

Lorsqu'une contrainte de clé étrangère n'est plus nécessaire dans une table, elle doit être supprimée de la table. Une fois la clé étrangère supprimée, l'association entre la table maître et la table esclave sera libérée.

Le format de syntaxe pour supprimer les contraintes de clé étrangère est le suivant :

ALTER TABLE <表名> DROP FOREIGN KEY <外键约束名>;
Copier après la connexion

Exemple 3

Supprimer la contrainte de clé étrangère fk_tb_dept1 dans la table de données tb_emp2 , SQL Les instructions et les résultats d'exécution sont présentés ci-dessous.

mysql> ALTER TABLE tb_emp2
    -> DROP FOREIGN KEY fk_tb_dept1;
Query OK, 0 rows affected (0.19 sec)
Records: 0  Duplicates: 0  Warnings: 0
mysql> SHOW CREATE TABLE tb_emp2\G
*************************** 1. row ***************************
       Table: tb_emp2
Create Table: CREATE TABLE `tb_emp2` (
  `id` int(11) NOT NULL,
  `name` varchar(30) DEFAULT NULL,
  `deptId` int(11) DEFAULT NULL,
  `salary` float DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `fk_tb_dept1` (`deptId`)
) ENGINE=InnoDB DEFAULT CHARSET=gb2312
1 row in set (0.00 sec)
Copier après la connexion

Vous pouvez voir que FOREIGN KEY n'existe plus dans tb_emp2 et que la contrainte de clé étrangère d'origine nommée fk_emp_dept est supprimée avec succès.

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