Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.11.28;
Скачать: CL | DM;

Вниз

Что быстрее: WHERE IN ... или WHERE ... OR ... OR ...   Найти похожие ветки 

 
Геннадий   (2004-10-29 07:41) [0]

Необходимо проверить на присутствие/отсутствие в таблице некоторые элементы (~50 000, varchar(20)). Что отработает быстрее?

select count(*) from table t where t.field in ("", "", ..., "")

или

select count(*) from table t where t.field = "" or t.field = "" or ...

В таблицу добавляется информация, которая в рамках этой таблицы должна быть уникальной. Причём проверка выполняется отдельно, а не при добавлении - пользователь должен иметь возможность узнать возможно ли теоритически добавить данные в таблицу (даже если самого добавления не планируется). Программно эти 50 000 разбиваются на части (500) и каждая часть проверяется отдельным запросом. Если все запросы вернули нули - элементы уникальны.
Может подскажете иной, более быстрый вариант?


 
Anatoly Podgoretsky ©   (2004-10-29 07:43) [1]

Почему бы тебе не измерить?


 
Johnmen ©   (2004-10-29 09:17) [2]

>Может подскажете иной, более быстрый вариант?

Оба одинаково не будут проходить компиляцию.
50 000 это не то количество...:)

А вообще почитай теорию, про индексы там, про предикаты (IN и т.д.), про вычисление логических выражений...


 
VictorT ©   (2004-10-29 13:18) [3]

имхо, лучше создать таблицу, в которой будут эти элементы, которые нужно проверит.
И тогда запрос будет типа такого
select count(*) from table t where t.field in select  field from table2


 
Johnmen ©   (2004-10-29 13:29) [4]

>VictorT ©   (29.10.04 13:18) [3]

Совершенно верно.
А если пойти дальше, то и запрос сделать с соединением.
А если ещё дальше в суть вопроса, то проектировать надо грамотно, тогда и вопросов таких не будет.


 
AZDesign   (2004-10-29 13:57) [5]

Во-первых, вставляется как правило ОДИН элемент и его нужно проверить, или ты сливаешь две таблицы - но это другой вопрос.

Если это ОДИН элемент, то нужно уйти от текстового поля, так как сравнение текста много дольше чисел.
Преобразуй текстовое поле в уникальное число и проверяй уникальное число по интексу. Работает чрезвычайно быстро

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


 
Vemer ©   (2004-10-29 14:38) [6]

Часто Where IN успешно можно заменить на Where Exists..



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

Текущий архив: 2004.11.28;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.044 c
1-1100264537
grig_p
2004-11-12 16:02
2004.11.28
Обрезание текста в ListView


14-1100284478
Cheater
2004-11-12 21:34
2004.11.28
Граждане! У кого есть Acrobat Reader!


1-1100254160
denis24
2004-11-12 13:09
2004.11.28
пернос слов с memo


4-1098095790
Basket
2004-10-18 14:36
2004.11.28
Не все отображаются процессы под Windows XP SP2


14-1100278843
Barlog
2004-11-12 20:00
2004.11.28
Форум