Comprendre ON UPDATE CASCADE dans les relations avec les bases de données
Scénario :
Lors de la conception des relations entre bases de données, il est crucial de déterminer l'utilisation appropriée de ON UPDATE CASCADE
. Contrairement à son homologue plus couramment utilisé, ON DELETE CASCADE
, ON UPDATE CASCADE
a des applications spécifiques.
Examinons un exemple typique :
<code class="language-sql">CREATE TABLE parent ( id INT NOT NULL AUTO_INCREMENT, PRIMARY KEY (id) ); CREATE TABLE child ( id INT NOT NULL AUTO_INCREMENT, parent_id INT, INDEX par_ind (parent_id), FOREIGN KEY (parent_id) REFERENCES parent(id) ON UPDATE CASCADE );</code>
ON DELETE CASCADE
supprime automatiquement les enregistrements enfants lorsque leur enregistrement parent associé est supprimé. ON UPDATE CASCADE
, cependant, concerne les mises à jour de la clé primaire du parent.
Candidature SUR CASCADE DE MISE À JOUR :
ON UPDATE CASCADE
apparaît lorsque la clé primaire de la table parent n'est pas auto-incrémentée ni horodatée. Dans ces cas, il met automatiquement à jour le parent_id
dans la table enfant chaque fois que la clé parent correspondante est modifiée.Cas d'utilisation supplémentaires :
ON UPDATE CASCADE
propage en douceur ces modifications aux tables associées.ON UPDATE CASCADE
peut améliorer les performances en éliminant le besoin de mises à jour individuelles des enregistrements enfants.Intégrité des données :
parent_id
d'un enregistrement enfant vers une valeur inexistante dans la table parent entraînera une violation de contrainte de clé étrangère. Ce comportement cohérent dans tous les systèmes de bases de données préserve l'intégrité des données.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!