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

Вниз

Как задать диапазон в SQL?   Найти похожие ветки 

 
Behemoth ©   (2003-10-20 10:52) [0]

Простите за глупый вопрос, но как правильнее написать на синтаксисе SQL нечто типа:
select * from table where Field in (50,70..95,100..160,200..500)


 
Alex_Bredin ©   (2003-10-20 10:57) [1]

так и пиши


 
bushmen ©   (2003-10-20 10:58) [2]

Так и правильно, через запятую.


 
Alex_Bredin ©   (2003-10-20 10:58) [3]

+ between для диапазонов


 
Behemoth ©   (2003-10-20 11:07) [4]

Проблема с диапазонами...
Этот запрос идет в цикле, и каждый раз там разное количество диапазонов, поэтому через between писать умучаешся (ужасно некрасиво получится), а через точки не проходит. Может есть другой путь?


 
Romkin ©   (2003-10-20 11:13) [5]

Думаю, возможно через временную таблицу, есть же in (select ...)


 
Семен Сорокин ©   (2003-10-20 11:13) [6]

Этот запрос идет в цикле, и каждый раз там разное количество диапазонов, поэтому через between писать умучаешся (ужасно некрасиво получится), а через точки не проходит. Может есть другой путь?
динамически строй запрос в зависимости от диапазонов.


 
Alex_Bredin ©   (2003-10-20 11:17) [7]

формируй динамически условие запроса
что-то типа query.SQL.add("or (exp1 between "+inttostr(x1)+" and "+inttostr(x2)+")");итп


 
Behemoth ©   (2003-10-20 11:17) [8]

to Romkin: продолжи свою мысль...
to Семен Сорокин: придется если не найдется более красивого решения


 
MOA ©   (2003-10-20 11:21) [9]

Если есть возможность, можно завести временную таблицу, примерно так
DECLARE @Tmp_tab TABLE(
StartVal Integer,
EndVal Integer NULL
... - поле для критериев отбора диапазонов - ведь как-то Вы решаете, какие диапазоны включить для итерации
)
Затем заполнить её, и

select * from table INNER JOIN @Tmp_tab ON (Field >=StarVal) AND ((Field <=EndVal) OR EndVal IS NULL) AND .... - условия для отбора из @Tmp_tab

Кстати, получится быстрее, чем с IN
Удачи!


 
Anatoly Podgoretsky ©   (2003-10-20 11:25) [10]

Это не диапазон, а множество "set of comparison values"


 
Behemoth ©   (2003-10-20 11:39) [11]

to Anatoly Podgoretsky:
к чему ты это.... есть возможность переменной присвоить множество?


 
Anatoly Podgoretsky ©   (2003-10-20 11:47) [12]

Я к тому, что предикат IN оперирует костантным множеством, где элементы разделеных запятыми

The set of comparison values may be either static using a comma-separated list of literals or dynamic using the result set from a subquery

Не знаю, возможно MSSQL и отходит от стандарта, но весьма сомневаюсь.



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

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

Наверх




Память: 0.49 MB
Время: 0.036 c
3-40801
Михаил
2003-10-22 14:47
2003.11.13
При открытие запроса в сервисе WinNT ошибка. Не могу получить дан


1-41636
atmospheric
2003-10-25 16:58
2003.11.13
Ключи


3-40966
Sandman25
2003-10-16 17:18
2003.11.13
Paradox: Select id, (select sum( ...


3-41081
Layner
2003-10-22 14:54
2003.11.13
Посоветуйте клиента для Access, минимум как Query Analyzer


1-41521
maestro
2003-10-28 07:55
2003.11.13
уничтожение компонента Button