×


Новости и мир Искусство Афоризмы История и факты
-----------

Политика конфидициальности Разместить рекламу

Удаление дубликатов строк из таблицы MySQL


дубликаты, похожие, похожие строки, дубликаты строк, удалить дубликаты строк, удалить похожие строки, избавиться, от дубликатов, от строк, удалить дублирующиеся строки, php, mysql, sql, phpmyadmin, избавление, удалить, удаление, повторы, повторяющиеся, строки, строка, данные, бд, db, база данных, таблица, таблицы,

--- DanJam. Свобода. Правда. Жизнь ---

Иногда после заполнения таблицы или импорта в неё разных строк бывает, что появляются похожие строки и данные, которые нужно удалить.
Для того, чтобы удалить похожие строки (дубликаты) и оставить одну нужную, используйте следующий 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"

*Мы не заставляем вас верить описанной информации выше. Любую информацию рекомендуем проверить в разных источниках.

Мы рады, спасибо! Увы, у нас нет рейтинговой системы - мы не повышаем статьи на основе лайков или дизлайков. Однако, если вы поделитесь ссылкой на статью - это будет лучшей благодарностью.

Увы, да. Возможно и такое. Мысли - достаточно сложная вещь. Кому-то они не понравятся, а кому-то покажутся интересными. Но кто в этом случае будет "прав" больше?










Norway
Стрижка никак не влияет на скорость роста волос.

[ Интересные факты о мире ]


Как поставить шрифт для своего сайта?

html

Как вставить данные в базу данных (таблицу)?

html

Список поддерживаемых системных шрифтов в css и html

html

Как написать текст на картинке, с помощью CSS + html?

html




Отношения и любовь Политика Тунис Петербург Тайны истории Статьи html, css, js, php Новости Турция Общество факты и мир Крым Психология Выборг Мистика






×

Рассказы из категории: Создание сайта (html,css,php,js)