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

Вниз

Еще вопросик по SQL.   Найти похожие ветки 

 
mik   (2002-03-27 12:44) [0]

Может подскажите, как в одном запросе реализовать след.
Выбери поле 1 если поле2 > 0 иначе выбери поле3.
Короче говоря, как реализовать конструкцию if else


 
Reindeer Moss Eater   (2002-03-27 12:51) [1]

Таких заморочек не возникает если соблюдать хотя бы первые три нормальные формы при проектировании таблиц.


 
mik   (2002-03-27 13:09) [2]

А может как-нибудь можно реализовать все-таки?


 
SEM ©   (2002-03-27 13:15) [3]

Для FoxPro вроде можно использовать IIF в SQL запросе.
Для MSSQL соответственно CASE
Для DBASE вроде нет подобного, хотя могу ошибаться.
Проще, создать вычисляемое поле для TQuery и там написать всю логику.


 
MAxiMum ©   (2002-03-27 13:16) [4]

В одном запросе, IMHO, не получится.
Сделай хранимую процедуру или напиши прогрумму в родной СУБД (dBase или FoxPro).


 
mik   (2002-03-27 14:10) [5]

Мда...жалко однако


 
Lusha ©   (2002-03-27 14:24) [6]

SELECT FIELD1
FROM TABLE1
WHERE FIELD2 > 0
UNION
SELECT FIELD3
FROM TABLE1
WHERE FIELD2 <= 0


 
Внук ©   (2002-03-27 15:26) [7]

Реализовать условный оператор в общем виде IMHO невозможно стандартом SQL, но конкретно Ваш случай описывается таким запросом:
SELECT DECODE(GREATEST(Поле2,0),0,Поле3,Поле1) as Имя_Поля
FROM ...

GREATEST(Поле2,0) дает, очевидно, 0 если Поле2<=0, тогда выбиратся Поле3, иначе выбирается Поле1. Эта конструкция работает в ORACLE. Не знаю, насколько она стандартна, но вдруг будет работать и у Вас, в противном случае, наверное, можно подобрать ее аналог. Выбираемые поля, конечно, должны быть в этом случае совместимы.


 
Shaman_Naydak ©   (2002-03-27 22:36) [8]

>> Внук
Как это - CASE - это как раз таки очень даже по стандарту,
да и решение через UNION пройдет абсолютно везде.


 
Внук ©   (2002-03-28 10:06) [9]

>>Shaman_Naydak ©
Наверное, это уже какой-то продвинутый стандарт, я ориентируюсь на более ранние.
Вариант с UNION, конечно, самый простой и разумный, нет вопросов. Свой вариант я привел, потому что захотелось суметь сделать выборку действительно ОДНИМ запросом, как требуется по условию, то есть просто размять мозги. UNION в этом смысле все-таки упрощение, хоть и выполняется одним пакетом.



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

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

Наверх




Память: 0.48 MB
Время: 0.008 c
1-57815
Дима2
2002-04-01 18:49
2002.04.18
DialogSave


1-57686
UDS
2002-04-07 20:35
2002.04.18
Как стрингу передать нецелое число и наоборот?


7-57900
XM-AD
2002-01-23 13:29
2002.04.18
Oops! Проблемка!!!


7-57899
Nikolay
2002-01-24 08:37
2002.04.18
DRV


1-57791
MaxSit
2002-04-04 20:45
2002.04.18
Передать из DLL большую строку