Форум: "Базы";
Текущий архив: 2004.11.21;
Скачать: [xml.tar.bz2];
Внизпростой вопрос по выборке из 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;
Скачать: [xml.tar.bz2];
Память: 0.44 MB
Время: 0.032 c