Maison > Article > base de données > Quelle est l'instruction SQL pour créer une contrainte de clé étrangère de table ?
Les contraintes de clé étrangère SQL peuvent être spécifiées via le mot-clé FOREIGN KEY, et l'instruction de création est "ALTER TABLE nom de la table ADD CONSTRAINT nom de la clé étrangère FOREIGN KEY (nom de la colonne) REFERENCES nom de la table principale (nom de la colonne);" .
L'environnement d'exploitation de ce tutoriel : système windows7, version mysql8, ordinateur Dell G3.
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.
Créer des contraintes de clé étrangère de table
Vous pouvez spécifier des clés étrangères via le mot-clé FOREIGN KEY dans l'instruction ALTER TABLE ajouter des contraintes de clé étrangère ; Le principe 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 spécifique est le suivant :
ALTER TABLE <数据表名> ADD CONSTRAINT <外键名> FOREIGN KEY(<列名>) REFERENCES <主表名> (<列名>);
Lors de la définition de clés étrangères, vous devez respecter les règles suivantes
La table principale doit avoir Existe dans la base de données, ou est-ce 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 la 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.
Exemple :
Modifiez la table de données tb_emp2, définissez le champ deptId comme clé étrangère et comparez-le avec la clé primaire ID de clé de la table de données tb_dept1 La corrélation, l'instruction SQL et les résultats d'exécution sont présentés ci-dessous.
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)
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.
(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!