sql >> Database >  >> RDS >> Mysql

Hoe dubbele rijen uit een MySQL-tabel te verwijderen

DELETE DupRows.*
FROM MyTable AS DupRows
   INNER JOIN (
      SELECT MIN(ID) AS minId, col1, col2
      FROM MyTable
      GROUP BY col1, col2
      HAVING COUNT(*) > 1
   ) AS SaveRows ON SaveRows.col1 = DupRows.col1 AND SaveRows.col2 = DupRows.col2
      AND SaveRows.minId <> DupRows.ID;

Natuurlijk moet je col1, col2 op alle drie de plaatsen uitbreiden naar alle kolommen.

Bewerken:ik heb dit zojuist uit een script gehaald dat ik bewaar en opnieuw heb getest, het wordt uitgevoerd in MySQL.



  1. De top 5 functies die uw SQL Server Database Performance Monitoring Platform moet bieden

  2. Databases en gegevensbestanden migreren

  3. Basisprincipes van PostgreSQL-schemabeheer

  4. Een overzicht van pgModeler voor PostgreSQL