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

Вниз

простой вопрос по выборке из ib баз   Найти похожие ветки 

 
Maxim_____   (2004-10-21 00:47) [0]

Извините за глупый вопрос.
Есть некоторый массив челых чисел,
от одного до 10000.
numarr array of integer;
Пишу запрос
select * from tablename where (fld21=213) and
((fld15= numarr[0]) or(fld15= numarr[1]) or(fld15= numarr[2]) or ...... )
т.е. получается очень длинный текст запроса с этим OR
Как-то это нехорошо смотрится, неоптимально,
может быть сущёствует более простой способ?
Может быть есть какой-нибудь ibx компонент, который может это упростить, а то большая часть траффика уйдет на текст запроса.


 
ЮЮ ©   (2004-10-21 02:40) [1]

И откуда, интересно, этот массив возник?


 
Наталия ©   (2004-10-21 07:37) [2]

Может быть так подойдет?
select * from tablename where (fld21=213) and
fld15 between numarr[0] and numarr[9999]
При условии, что в numarr[0] - наименьшее целое число,
а в numarr[9999] - наибольшее.
Или нужно более конкретно задачу сформулировать, тогда, возможно, ещё какие-то условия появятся...


 
msguns ©   (2004-10-21 09:39) [3]

ИМХО, в таких случаях, предпочтительнее вместо длиннючего текста запроса использовать ссылочный НД, который можно получить как временную таблицу и соответствующим образом заполнить.
А вообще-то разделяю недоумение ЮЮ ©   (21.10.04 02:40) [1]



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

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

Наверх




Память: 0.47 MB
Время: 0.048 c
3-1098296531
ввх
2004-10-20 22:22
2004.11.21
Ошибка при закрытии программы


14-1099672063
Agent13
2004-11-05 19:27
2004.11.21
Delphi 8, 9 и WinXP Home


14-1098957474
kaif
2004-10-28 13:57
2004.11.21
За свободу !


4-1097000845
DeScriptor
2004-10-05 22:27
2004.11.21
Поиск по реестру, сканирование реестра


14-1099488671
Руслана
2004-11-03 16:31
2004.11.21
Не знает ли кто компонет типа TrackBar только с линейкой