Maison > Article > base de données > Mysql supprime les données en double et conserve le plus petit identifiant
Recherchez et supprimez les données en double sur Internet et conservez les données avec le plus petit identifiant. La méthode est la suivante :
DELETE FROM people WHERE peopleName IN ( SELECT peopleName FROM people GROUP BY peopleName HAVING count(peopleName) > 1 ) AND peopleId NOT IN ( SELECT min(peopleId) FROM people GROUP BY peopleName HAVING count(peopleName) > 1 )
Lorsque vous l'utilisez vous-même, un message d'erreur s'affiche :
1 delete from tb where id in (SELECT max(id) from tb GROUP BY user HAVING count(user)>1)
[Err] 1093 - Vous ne pouvez pas spécifier la table cible 'XXX' pour la mise à jour dans la clause FROM
Je ne sais pas encore quelle en est la cause.
Trouvez ensuite un moyen de répartir les opérations. Commencez par filtrer les données avec les utilisateurs en double, puis utilisez max() pour sélectionner la plus grande ligne :
SELECT max(id) from tb. GROUP BY user HAVING count(user)>1
Puis supprimez les données redondantes une par une selon le max(id) obtenu
1 delete from tb where id=xx
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!