sql >> Base de Datos >  >> RDS >> Mysql

elimine filas duplicadas y necesite conservar una de todas ellas en mysql

DELETE  a
FROM    tableA a
        LEFT JOIN
        (
            SELECT MIN(ID) ID, Name, Phone
            FROM    TableA
            GROUP   BY Name, Phone
        ) b ON  a.ID = b.ID AND
                a.NAme = b.Name AND
                a.Phone = b.Phone
WHERE   b.ID IS NULL

Después de haber ejecutado la declaración de eliminación, imponga una restricción única en la columna para que no pueda volver a insertar registros duplicados,

ALTER TABLE TableA ADD CONSTRAINT tb_uq UNIQUE (Name, Phone)