Иногда после заполнения таблицы или импорта в неё разных строк бывает, что появляются похожие строки и данные, которые нужно удалить.
Для того, чтобы удалить похожие строки (дубликаты) и оставить одну нужную, используйте следующий mysql-запрос:
Вариант 1:
Выполняется в 4 запроса. Сначала запрос автоматически создает временную таблицу, очищает ее, заносит в нее id только уникальных записей и удаляем из основной таблицы записи с теми id, которые не попали во временную. (естественно, если у вас большая таблица (в несколько сотен тысяч строк), то обработка запроса займет много времени - это нормально)
Условие: есть таблица "table" и строки "id", email - колонка, где есть дублирующиеся адреса пот клиентов. нам нужно избавиться от вторых дублей.
CREATE TEMPORARY TABLE IF NOT EXISTS temp_table(`id` int(10)) ENGINE=MEMORY;
TRUNCATE TABLE temp_table;
INSERT INTO `temp_table` (SELECT MIN(id) as id FROM `table` GROUP BY `email`);
DELETE FROM `table` WHERE `id` NOT IN (SELECT `id` FROM `temp_table`);
temp_table - в примере выше, временная таблица, которая автоматиески создастся и удалится
email - коллонка, где есть дубликаты и которые нужно удалить.
Вариант 2:
Второй вариант, как удалить дубликаты строк из таблицы MySQL гораздо проще. Мы просто делаем JOIN таблицы на саму себя по условию равенства полей, удаляя записи с большим id.
DELETE t1 FROM `table` t1, `table` t2 WHERE t1.email=t2.email AND t1.id > t2.id
Лично я чаще всего использую вариант 2, но вариант 1 тоже хорош, для того что бы удалить дубликаты строк MySQL
ВАЖНО!!! Перед началом испробуте эти таблицы на своем домашнем сервере (локальном), а уже потом работайте с таблицей на реальном сервере. Это нужно т.к. с локального легче сохранить базы данных, чем с реального. p.s. или можете просто создать тестовую таблицу с данными и назвать её "test_table"