Prévenir les entrées en double dans la base de données MySQL
Le maintien de l'intégrité des données est crucial dans la gestion de la base de données. Lors de l'insertion de nouveaux enregistrements, il est essentiel d'éviter les entrées en double pour garantir la cohérence des données. Ceci est particulièrement important dans les scénarios où l'unicité de certains champs est requise.
Considérez une table avec des colonnes id (clé primaire), pageId (clé étrangère) et nom. Un script PHP insère 5 000 enregistrements dans cette table, dont environ la moitié sont des doublons ayant le même identifiant de page et le même nom. Le défi consiste à empêcher l'insertion de ces doublons.
Clé unique et stratégies de gestion
La première étape consiste à établir une clé unique sur la table :
ALTER TABLE thetable ADD UNIQUE INDEX(pageid, name);
Cela garantit qu'aucune combinaison en double de pageId et de nom ne peut être insérée.
Ensuite, il est important pour déterminer l'action appropriée lorsqu'un doublon est rencontré. Il existe plusieurs stratégies à considérer :
1. Ignorer les VALEURS en double
INSERT IGNORE INTO thetable (pageid, name) (1, "foo"), (1, "foo");
Cette méthode ignore simplement l'insertion du double enregistrement.
2. Écraser l'enregistrement précédent
`INSERT INTO thetable (pageid, name, somefield)
VALUES (1, "foo", "first")
ON DUPLICATE KEY UPDATE (somefield = ' premier')
INSERT INTO thetable (pageid, name, somefield)
VALUES (1, "foo", "second")
ON DUPLICATE KEY UPDATE (somefield = 'second')`
Avec cette approche, l'enregistrement en double écrase l'enregistrement précédemment inséré, en remplaçant la valeur somefield.
3. Mettre à jour un compteur
`INSERT INTO thetable (pageid, name)
VALUES (1, "foo"), (1, "foo")
ON DUPLICATE KEY UPDATE (pagecount = pagecount 1)`
Ici, l'insertion de doublons met à jour la colonne nombre de pages, en incrémentant sa valeur pour chaque doublon rencontré.
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!