Mysql
 sql >> Database >  >> RDS >> Mysql

Come elimino tutti i record duplicati in una tabella MySQL senza tabelle temporanee

Aggiungi Indice unico sulla tua tavola:

ALTER IGNORE TABLE `TableA`   
ADD UNIQUE INDEX (`member_id`, `quiz_num`, `question_num`, `answer_num`);

Un altro modo per farlo sarebbe:

Aggiungi la chiave primaria nella tabella, quindi puoi rimuovere facilmente i duplicati dalla tabella utilizzando la seguente query:

DELETE FROM member  
WHERE id IN (SELECT * 
             FROM (SELECT id FROM member 
                   GROUP BY member_id, quiz_num, question_num, answer_num HAVING (COUNT(*) > 1)
                  ) AS A
            );