Главная страница
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.032 c
4-1097486211
aleshap
2004-10-11 13:16
2004.11.21
Как в программе определить, что запустилась "Заставка Экрана"?


14-1098581802
Думкин
2004-10-24 05:36
2004.11.21
С днем рождения! 24 октября


14-1099169352
vecna
2004-10-31 00:49
2004.11.21
Парсинг DFM


3-1098770649
AlexTregubov
2004-10-26 10:04
2004.11.21
Fast Report


1-1099585624
heady
2004-11-04 19:27
2004.11.21
выбор папки с кнопкой "создать"