Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Начинающим";
Текущий архив: 2008.12.28;
Скачать: [xml.tar.bz2];

Вниз

удилить дубликаты строк MS SQL Server   Найти похожие ветки 

 
ekto ©   (2008-11-18 14:57) [0]

всем привет!
сабж.
пока сделал следующее:

SELECT *
 FROM text_to_tree
WHERE tree_id IN (SELECT tree_id
                    FROM text_to_tree
                  GROUP BY tree_id, text_id
                  HAVING COUNT(*) >1)
  AND text_id IN (SELECT text_id
                    FROM text_to_tree
                  GROUP BY tree_id, text_id
                  HAVING COUNT(*) >1)
ORDER BY tree_id, text_id

получаю список дубликатов. А что дальше делать?
Подскажите, плиз.


 
clickmaker ©   (2008-11-18 15:02) [1]

> А что дальше делать?

а какие из дублей требуется удалить?
уникальный ключ есть?


 
ekto ©   (2008-11-18 15:04) [2]


> clickmaker ©   (18.11.08 15:02) [1]

не, уникальным ключем будут, впоследствии, два поля: tree_id и text_id


 
clickmaker ©   (2008-11-18 15:07) [3]

ну если надо оставить один из дублей, значит надо как-то его отличить от остальных, ведь так?


 
ekto ©   (2008-11-18 15:09) [4]


>
> clickmaker ©   (18.11.08 15:07) [3]

так, вот я и спрашиваю, как пронумеровать только свои дубликаты:)


 
Palladin ©   (2008-11-18 15:10) [5]


> А что дальше делать?

простым запросом - ничего

выбрать с помощью курсора данные, бежать по нему (курсору) вставляя во временную таблицу
помечать строку (ни разу не встретившуюся во временной таблице) флагом "первой строки", остальные флагом "дублей"
удалить все из исходной таблицы
вставить в исходную таблицу все строки из временной с "флагом первой строки"


 
ekto ©   (2008-11-18 15:13) [6]


> Palladin ©   (18.11.08 15:10) [5]

понятно, спасибо.

ps. Не, однако че-бы в сиквелсервере не ввести уник строки, как интерьейзе?


 
Anatoly Podgoretsky ©   (2008-11-18 15:17) [7]

А сервер у тебя какой?


 
clickmaker ©   (2008-11-18 15:18) [8]

переименуй таблицу в xxx_dup, н-р
исходную создай заново
далее вставляй в свежесозданную из xxx_dup с проверкой if not exists


 
ekto ©   (2008-11-18 15:21) [9]

клева, спасибки

но эт один фик с курсором?


 
Palladin ©   (2008-11-18 15:24) [10]


> clickmaker ©   (18.11.08 15:18) [8]

угу, так даже оптимальней...


 
Palladin ©   (2008-11-18 15:26) [11]

ну а на самом деле правильно: не допускать появления этих строк на момент заполнения таблицы


 
ekto ©   (2008-11-18 15:29) [12]


> Palladin ©   (18.11.08 15:26) [11]

это-то я знаю:)


 
Ega23 ©   (2008-11-18 15:52) [13]


> ps. Не, однако че-бы в сиквелсервере не ввести уник строки,
>  как интерьейзе?


Они там есть. Просто ты не умеешь ими пользоваться...


 
Anatoly Podgoretsky ©   (2008-11-18 15:55) [14]

> Ega23  (18.11.2008 15:52:13)  [13]

Он просто плюет, когда его спрашивают какой у него сервер, наверно думает, что есть только один сервер.


 
b z   (2008-11-18 16:19) [15]

http://support.microsoft.com/kb/139444/ru
похоже на > clickmaker ©   (18.11.08 15:18) [8] :)


 
ekto ©   (2008-11-18 16:21) [16]


> Anatoly Podgoretsky ©   (18.11.08 15:55) [14]

2005


 
Anatoly Podgoretsky ©   (2008-11-18 16:23) [17]

> ekto  (18.11.2008 16:21:16)  [16]

В 2005 есть нумерация строк.


 
ekto ©   (2008-11-18 16:34) [18]


> Anatoly Podgoretsky ©   (18.11.08 16:23) [17]

не отыскал:(


 
stas ©   (2008-11-18 16:37) [19]

Добавь поле id - автоинкрементное и оставь те у которых минимальный id


 
Anatoly Podgoretsky ©   (2008-11-18 17:04) [20]

> ekto  (18.11.2008 16:34:18)  [18]

Ты не только не отыскал, но ты еще и не там задаешь вопрос, правда его и задавать не надо. Иди на SQL.RU у них там это вопрос входит в TOP 10 FAQ
Правда тебя там будут бить за подобную методику обсуждения.



Страницы: 1 вся ветка

Форум: "Начинающим";
Текущий архив: 2008.12.28;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.49 MB
Время: 0.008 c
4-1202738807
Unicode
2008-02-11 17:06
2008.12.28
TLogFontW и DrawTextW


15-1225294974
Правильный$Вася
2008-10-29 18:42
2008.12.28
сжатие звука в VirtualDub


2-1226824815
NoDt
2008-11-16 11:40
2008.12.28
Как вызвать событие перерисовки формы.


2-1226901427
Mery
2008-11-17 08:57
2008.12.28
Update


15-1225098322
guav
2008-10-27 12:05
2008.12.28
Раскритикуйте бред С++ника :)





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский