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

Вниз

singleton-набор данных   Найти похожие ветки 

 
zorik ©   (2004-07-15 09:33) [0]

Есть таблица с полем дата и другими информативными полями. Пользователь задает дату и если запись с такой датой есть в таблице - процедура должна вернуть одну запись именно с этой датой, если нет - предыдущюю запись.
Вопрос. Вернет ли такая конструкция именно то что нужно. Когда проходит сортировка в теле for select - do или после всего перебора?

FOR
   SELECT date1, a1
   FROM D01
   WHERE date1<=:userdate
   order by date1 desc
   INTO :date1, :a1
 DO
 BEGIN
   SUSPEND;
   EXIT;
 END


 
Johnmen ©   (2004-07-15 09:49) [1]

FOR - это оператор цикла
после DO - оператор тела цикла, в т.ч. и бегин-блок

То, что ты хочешь, можно просто запросом
SELECT *
FROM D01 T1
WHERE T1.date1=(SELECT MAX(T2.date1)
               FROM D01 T2
               WHERE T2.date1<=:userdate)


 
zorik ©   (2004-07-15 09:58) [2]

Спасибо! А то что я написал правильно работает? Сначала отсортируется а потом вылетит по EXIT или может выйти раньше из процедуры?


 
Johnmen ©   (2004-07-15 10:00) [3]

Правильно.


 
zorik ©   (2004-07-15 10:04) [4]

Спасибо!



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

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

Наверх




Память: 0.47 MB
Время: 0.022 c
1-1090669815
sloug
2004-07-24 15:50
2004.08.08
Unit


1-1090984252
superedward
2004-07-28 07:10
2004.08.08
ActionManager + ActionMainMenuBar в run-time


1-1090570398
ColoredCD-R
2004-07-23 12:13
2004.08.08
Одновременная посылка сообщения всем дочерним потокам


14-1090564524
alsov
2004-07-23 10:35
2004.08.08
Какой инсталятор выбрать


3-1089642536
Viz
2004-07-12 18:28
2004.08.08
Дублирующиеся записи в таблице