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... » ?

Comment supprimer les lignes en double d'une table SQL sans l'erreur « Vous ne pouvez pas spécifier la table cible... » ?

Linda Hamilton
Linda Hamiltonoriginal
2024-11-01 01:12:011019parcourir

How to Delete Duplicate Rows from an SQL Table without the

Suppression des lignes en double d'une table SQL

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn