Maison > base de données > tutoriel mysql > le corps du texte

Mysql supprime les données en double et conserve le plus petit identifiant

一个新手
Libérer: 2017-10-13 10:11:18
original
2103 Les gens l'ont consulté

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
)
Copier après la connexion

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)
Copier après la connexion

[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
Copier après la connexion

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal