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

Вниз

local SQL запрос: выбрать 5 максимальных   Найти похожие ветки 

 
фл   (2002-06-14 11:28) [0]

Никак не получается сделать запрос. Надо получить значения field1, где field2 по этой же записи -- одно из 5 максимальных значений по этому полю в бд. Причем если, скажем, максимальные значения field2 - 33, 31, 28, 27, 26, 26, 26, то должно получиться 7 значений field1. Надеюсь понятно почему.
Можно ли вообще сделать это одним запросом?


 
fnatali ©   (2002-06-14 11:42) [1]

Мне кажется, что одним запросом не получится.
query1.sql.clear;
query1.sql.add("select field1 from table order by field2 desc");
query1.open;
query1.first;
for i:=1 to 7 do
begin
делай что тебе нужно с выбранными записями
query1.next;
end;


 
Val ©   (2002-06-14 11:47) [2]

думаю врядли получится одним запросом. Предлагаю такой вариант:
select distinct field2 from mytable
order by field2
затем в цикле по данному квери вытягиваете пять последних значений.
затем подставить полученные значения в параметрический запрос:
select field1 from mytable where field2 in(:par1,:par2,:par3,:par4,:par5)


 
Val ©   (2002-06-14 11:52) [3]

>fnatali © (14.06.02 11:42) сорри за небольшой плагиат :)), написал, увидел ваш совет, решил дописать:
>фл (14.06.02 11:28)
украду из совета fnatali © (14.06.02 11:42) то, где стормозил, первый запрос лучше отсортировать по убыванию и взять первые пять записей.



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

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

Наверх




Память: 0.47 MB
Время: 0.013 c
14-23748
Fissher
2002-06-05 16:46
2002.07.08
Приближение к реальности :-)


4-23853
Alexeyk
2002-05-08 07:22
2002.07.08
Опять про иконку в трее!


14-23733
Kaban
2002-06-05 12:38
2002.07.08
Наши выигрывают 2-0.


4-23839
rog
2002-05-03 07:58
2002.07.08
не получается вытащищить СД!


14-23744
Сергей А.
2002-06-06 00:06
2002.07.08
Игры на Delphi