Maison >base de données >tutoriel mysql >Comment implémenter la cascade de clés étrangères MySQL
Les clés étrangères MySQL jouent un rôle contraignant et assurent l'intégrité des données au niveau de la base de données.
Par exemple, en utilisant le type de clés étrangères CASCADE (concaténation en cascade), lorsqu'une table enfant (telle que user_info) est associée à une table parent (telle que user), lorsque la table parent est mise à jour ou supprimée, la table enfant sera mettre à jour ou supprimer des enregistrements. Ce processus est effectué au niveau de la base de données.
Il existe de nombreuses conceptions de bases de données dans les premiers systèmes d'entreprise. Bien que cela aide les programmeurs à enregistrer les opérations de suppression et de mise à jour, cela augmente en réalité les règles cachées, augmente la complexité des logiciels et affaiblit les performances.
Ainsi, dans la conception d'applications, nous devons faire de notre mieux pour garantir l'intégrité des données au niveau de la couche application (par exemple en utilisant un mécanisme de traitement des transactions), plutôt qu'au niveau de la base de données.
Ce qui suit est une introduction aux clés étrangères de MySQL.
Le seul moteur de stockage qui prend en charge les clés étrangères dans MySQL est InnoDB Lors de la création d'une clé étrangère, il est nécessaire que la table parent ait un index correspondant. La table enfant sera également automatiquement créée. lors de la création d'une clé étrangère l'index correspondant.
Lors de la création d'un index, vous pouvez spécifier les opérations correspondantes à effectuer sur la table enfant lors de la suppression ou de la mise à jour de la table parent, notamment
RESTRICT (restriction de restriction)
NO ACTION
SET NULL
CASCADE (concaténation)
RESTRICT est identique à NO ACTION, ce qui signifie que la table parent ne peut pas être mise à jour lorsque la table enfant a des enregistrements associés
CASCADE signifie que la table parent ; est mis à jour ou supprimé Lorsque, met à jour ou supprime l'enregistrement correspondant de la table enfant ;
SET NULL signifie que lorsque la table parent est mise à jour ou supprimée, le champ correspondant de la table enfant est SET NULL.
Parce que seul le moteur InnoDB permet l'utilisation de clés étrangères, notre table de données doit utiliser le moteur InnoDB.
Créer une base de données :
Create database test;
create table stu( sid int UNSIGNED primary key auto_increment, name varchar(20) not null) TYPE=InnoDB charset=utf8; create table sc( scid int UNSIGNED primary key auto_increment, sid int UNSIGNED not null, score varchar(20) default '0', index (sid), --外键必须加索引 FOREIGN KEY (sid) REFERENCES stu(sid) ON DELETE CASCADE ON UPDATE CASCADE) TYPE=InnoDB charset=utf8;
– Remarque : les clés étrangères doivent être indexées
FOREIGN key(sid) Définissez la clé étrangère et définissez sid comme clé étrangère ; RÉFÉRENCES fonction de référence stu(sid). Référencez le sid dans la table stu
ON DELETE CASCADE cascade delete
ON UPDATE CASCADE cascade update
2 Insérez les données dans deux tables
insert into stu (name) value ('zxf'); insert into stu (name) value ('ls'); insert into stu (name) value ('zs'); insert into stu (name) value ('ww'); insert into sc(sid,score) values ('1','98'); insert into sc(sid,score) values ('1','98'); insert into sc(sid,score) values ('2','34'); insert into sc(sid,score) values ('2','98'); insert into sc(sid,score) values ('2','98'); insert into sc(sid,score) values ('3','56'); insert into sc(sid,score) values ('4','78'); insert into sc(sid,score) values ('4','98');
Remarque : lors de l'insertion de données dans la table sc, si le Si sid est inséré. est 22, l'insertion échouera, violant la contrainte de clé étrangère, car la clé étrangère sid
provient de la clé primaire de id dans la table stu, c'est-à-dire que l'identifiant dans stu n'a pas de données égales à 22.
Suppression en cascade : supprimez l'élève avec l'identifiant 2 dans la table stu, et les notes de l'élève dans la table sc seront également supprimées en cascade
delete from stu where sid = '2';
Mise à jour en cascade : l'élève avec l'identifiant 3 dans la table stu est remplacé par L'identifiant est 6, et l'identifiant correspondant de l'élève dans la table sc sera également mis à jour en cascade
update stu set sid=6 where sid='3';
Remarque
Lors de la suppression d'une table, vous devez d'abord supprimer la table de clé étrangère (sc), puis supprimer la table de clé primaire (stu)
L'image ci-dessus montre une violation de contrainte de clé étrangère et ne peut pas être supprimée
L'image ci-dessus montre une suppression normale Supprimez d'abord la table sc, puis supprimez la table stu. !
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!