информационная безопасность
без паники и всерьез
 подробно о проектеRambler's Top100
Spanning Tree Protocol: недокументированное применениеВсе любят мед
BugTraq.Ru
Русский BugTraq
 Анализ криптографических сетевых... 
 Модель надежности двухузлового... 
 Специальные марковские модели надежности... 
 Очередное исследование 19 миллиардов... 
 Оптимизация ввода-вывода как инструмент... 
 Зловреды выбирают Lisp и Delphi 
главная обзор RSN блог библиотека закон бред форум dnet о проекте
bugtraq.ru / форум / programming
Имя Пароль
если вы видите этот текст, отключите в настройках форума использование JavaScript
ФОРУМ
все доски
FAQ
IRC
новые сообщения
site updates
guestbook
beginners
sysadmin
programming
operating systems
theory
web building
software
hardware
networking
law
hacking
gadgets
job
dnet
humor
miscellaneous
scrap
регистрация





Легенда:
  новое сообщение
  закрытая нитка
  новое сообщение
  в закрытой нитке
  старое сообщение
MySQL - Выборка дублирующихся записей 19.06.05 01:45  
Автор: Cyber_Onix Статус: Незарегистрированный пользователь
<"чистая" ссылка>
Всем привет!
Не знаю, в тот ли раздел пишу, но надеюсь что да
есть такой вопрос: каким образом можно выбрать из таблицы все дублирующиеся записи?
имеется таблица в которой есть два поля id (int primary key) и string (text)
в тексте могут быть повторяющиеся записи, но у них будет разный id
как найти такие записи?
строка типа

Код:
select string from current where ((string = string) AND (id != id));

не дает желаемого результата
Я сталкивася с подобной задачей 19.06.05 03:05  
Автор: whiletrue <Роман> Статус: Elderman
Отредактировано 19.06.05 16:40  Количество правок: 4
<"чистая" ссылка>
Только мне надо было выбрать те записи, где сумма максимальна, а мой диалект SQL не поддерживал запись типа "having sum=max(sum)". Пришлось сделать тупо.

--------------------------------

Вот примерно так выбрать все повторяющиеся string
select string from current group by string having count(*)>1

Если надо еще и id, то придется 2 раза одну и ту же таблицу пользовать,
Т.к. count предполагает группировку, а группировать по id - будет не правильно :(

Вот примерно так:
select current.*
from
(select string from current group by string having count(*)>1) as strings
inner join
current
on
strings.string = current.string

Я бы предложил еще такой вариант:
select tab1.*
from
current as tab1
inner join
current as tab2
on
(tab1.string = tab2.string) AND (tab1.id != tab2.id)

.. но не знаю, есть ли в MySQL "distinct"
1




Rambler's Top100
Рейтинг@Mail.ru


  Copyright © 2001-2025 Dmitry Leonov   Page build time: 0 s   Design: Vadim Derkach