Maison >base de données >tutoriel mysql >Comment supprimer les lignes en double d'une table SQL sans l'erreur « Vous ne pouvez pas spécifier la table cible... » ?
Dans la gestion de bases de données, il est souvent nécessaire de supprimer les enregistrements en double d'une table. MySQL propose différentes façons d'y parvenir.
Une approche courante consiste à identifier les lignes en double à l'aide d'une requête telle que :
SELECT COUNT(empssn), empssn FROM employee GROUP BY empssn HAVING COUNT(empssn) > 1
Cette requête identifie les lignes avec des valeurs en double dans la colonne empssn. Pour supprimer ces doublons, vous pouvez utiliser la requête suivante :
DELETE FROM employee WHERE (empid, empssn) NOT IN (SELECT MIN(empid), empssn FROM employee GROUP BY empssn);
Cependant, cette approche peut entraîner l'erreur "Vous ne pouvez pas spécifier la table cible 'employé' pour la mise à jour dans la clause FROM." Pour résoudre ce problème, vous pouvez envelopper la sous-requête dans une table dérivée :
DELETE FROM employee WHERE (empid, empssn) NOT IN (SELECT empid, empssn FROM (SELECT MIN(empid) AS empid, empssn FROM employee GROUP BY empssn) X);
L'utilisation d'une table dérivée vous permet de référencer la table d'origine dans la sous-requête sans erreur. Cette approche supprime avec succès les lignes en double dans la table des employés tout en préservant la structure des données d'origine.
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!