Главная страница
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.01 c
1-23557
sergn
2002-06-25 21:12
2002.07.08
Очистка TTreeView


1-23583
Боева Наталья
2002-06-24 04:27
2002.07.08
отчет в word


1-23573
SergeyAndreichikov
2002-06-27 09:33
2002.07.08
Как использовать проинсталированные компоненты?


14-23727
DeepProg
2002-06-05 18:32
2002.07.08
ShellExecute


3-23480
Oleg_er
2002-06-14 07:01
2002.07.08
не лады с репортом :-(