Главная страница
    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.45 MB
Время: 0.033 c
1-1090522594
Боян Георгиев
2004-07-22 22:56
2004.08.08
Как емулировать нажатие PrintScreen-a?


4-1088592610
nik7777
2004-06-30 14:50
2004.08.08
Как перехватить изменения в реестре


3-1089787441
dk-soft
2004-07-14 10:44
2004.08.08
QuantumGrid доступ к данным через FIB


4-1088081391
S.A.S.
2004-06-24 16:49
2004.08.08
шина PCI


14-1090736418
Суслик
2004-07-25 10:20
2004.08.08
Отпуск





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский