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

Вниз

Есть ли альтернатива запросу с whrere in   Найти похожие ветки 

 
DimonNew   (2004-11-15 14:03) [0]

Привет, помогите пож-та. Есть Query, в который вставляется строка примерного вида с where field1 in (123,...,544). То, что перечисляется в in, заполняется как стока в Delphi и может быть несколько сотен чисел в ней. Так вот, программа зависает на некоторое время во время выполнения запроса и потом выдает ошибку, что истек TimeOut. Увеличение его не помогает. Подскажите пож-та, как можно избавиться от этого, может альтернативный запрос?


 
clickmaker ©   (2004-11-15 14:08) [1]

если есть непрерывность, то можно частично вместо in юзать between. На крайняк поднять св-во TimeOut у Query (если TADOQuery)


 
Ega23 ©   (2004-11-15 14:20) [2]

Я думаю, не в in дело.


 
Layner ©   (2004-11-15 14:22) [3]

123,...,544 - эти числа откуда берете? С др. таблицы? Тогда пожайлуста, пишите так: where field1 in (SELECT id FROM table WHERE ...) На стороне сервера это вычислится моментом.


 
DimonNew   (2004-11-15 14:22) [4]

Непрерывности нет. Время увеличил у ADOQuery до 300, прошло без ошибки,но очень долго ждал, пока Open этот запрос сделает.


 
Ega23 ©   (2004-11-15 14:26) [5]

123,...,544 - эти числа откуда берете? С др. таблицы? Тогда пожайлуста, пишите так: where field1 in (SELECT id FROM table WHERE ...) На стороне сервера это вычислится моментом.

Вопрос спорный. Я бы не стал так категорично утверждать.


 
Ega23 ©   (2004-11-15 14:27) [6]

Непрерывности нет. Время увеличил у ADOQuery до 300, прошло без ошибки,но очень долго ждал, пока Open этот запрос сделает.

Сам запрос оптимизировать никак?


 
DimonNew   (2004-11-15 14:28) [7]

Да это верно Layner © сам пробовал, но эти числа выбирает пользователь, вернее какие-то строки в ListBox, с которыми связаны идентификаторы, их-то я и загоняю в in, если их мало, то проходит запрос нормально, если много, то беда.


 
msguns ©   (2004-11-15 14:34) [8]

А тупо создать врем. таблицу, проиндексировать ее по "искомому" полю, вогнать туда все значения, отмеченные узером, а потом запустить связанный запрос ?



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

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

Наверх




Память: 0.48 MB
Время: 0.063 c
9-1091186589
OSG
2004-07-30 15:23
2004.12.12
Siege of Avalon !!!


4-1098854154
Shura
2004-10-27 09:15
2004.12.12
Создание прозрачного плавающего окна


4-1099049350
walruz
2004-10-29 15:29
2004.12.12
Ctrl+alt+del


14-1101124907
Comp
2004-11-22 15:01
2004.12.12
Инсталяция Turbo Assembler 5.0


6-1096286797
andrey__
2004-09-27 16:06
2004.12.12
модем. связь между 2-мя компами (её автоматизация)