Новости
Документация
Download
Webboard
Поиск
FAQ/ЧаВо
Обратная связь




MySQL.RU - Webboard



Вернуться
Удаление дублей из одной таблицы (berkut) 17/09/2005 - 03:41:34
      Re: Удаление дублей из одной таблицы (Lev) 17/09/2005 - 05:18:56
      Re: Удаление дублей из одной таблицы (Dinky) 17/09/2005 - 05:29:25

> Original message text:
> From: berkut - 17/09/2005 - 03:41:34
> Subject:Удаление дублей из одной таблицы
> -----------------
> Как удалить дубли из одной таблицы?[code]
> CREATE TABLE `t1` (
> `f1` int(11) unsigned NOT NULL auto_increment,
> `f2` varchar(200) NOT NULL default '',
> PRIMARY KEY (`f1`)
> ) ENGINE=MyISAM DEFAULT CHARSET=cp1251[/code]
> Данные:[code]
> f1 f2
>
> 1 HP
> 2 Intel
> 3 HP
> 4 HP
> 5 Intel[/code]
> Нужно что-бы остались только 2 записи: HP и Intel, с любыми id
>


From: Lev - 17/09/2005 - 05:18:56
Subject:Удаление дублей из одной таблицы
-----------------
По моим представлением, однимзапросом никак.
Сам решал подобные задачи двумя основными способами (вариации могут быть):
1. На клиенте утилитка, которая вызывает запрос, отсортированный по имени, и она перебирает рекордсет по строкам, удаляя каждую, которая совпадает с предыдущей.
2. Первым запросом формируем временную таблицу, в которой пишем сохраняемые записи (группировка по имени и сохранение id первой записи каждой группы). Вторым запросом удаляем записи, которые НЕ ИМЕЮТ связки с временной таблицей. Третьим запросом удаляем временную ТБ..
Ессно это только наброски, которые надо работать и работать...


[Это сообщение - спам!]

Последние сообщения из форума

Уважаемые посетители форума MySQL.RU!
Убедительная просьба, прежде чем задавать свой вопрос в этом форуме, обратите внимание на разделы:
- ответы на наиболее часто задаваемые вопросы - FAQ
- раздел документация
- раздел поиск по сообщениям форума и документации
Также, старайтесь наиболее подробно указывать свою ситуацию (версию операционной системы, версию MySQL, версию программного обеспечения, по которому возникает вопрос, текст возникающих ошибок, и др.)
Помните, чем конкретнее Вы опишете ситуацию, тем больше шансов получить реальную помощь.
 Имя:
 E-mail:
 Тема:
 Текст:
Код подтверждения отправки: Code
24053



РЕКЛАМА НА САЙТЕ
  Создание сайтов | |