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

Вниз

Помогите с запросом, пожалуйста.   Найти похожие ветки 

 
chtr ©   (2004-03-15 07:10) [0]

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

из

id | code | date | price
------------------------
1 | 12   | 1/01 | 250
2 | 13   | 1/01 | 800
3 | 12   | 1/02 | 253
4 | 13   | 1/02 | 795

надо получить

id | code | date | price
------------------------
3 | 12   | 1/02 | 253
4 | 13   | 1/02 | 795

Мне кажется кто-то уже такое должен был делать. Просто катастрофически нехватает времени, помогите пожалуйста.
Спасибо.


 
YurikGl ©   (2004-03-15 08:06) [1]

where id>2 ?


 
ЮЮ ©   (2004-03-15 08:39) [2]

SELECT tbl.*
FROM
 (SELECT Code, MAX(date) MaxDate FROM Table GROUP By Code) gr
 LEFT JOIN Table tbl ON (gr.Code = tbl.CODE) AND (gr.MaxDate = tbl.Date)

если же предположить, что большему ID большая дата (т.е. данные вводятся последовательно), то можно

SELECT tbl.*
FROM
 (SELECT Code, MAX(ID) MaxId FROM Table GROUP By Code) gr
 LEFT JOIN Table tbl ON (gr.MaxId = tbl.Id)


 
CHTR ©   (2004-03-15 09:04) [3]

2 ЮЮ , спасибо огромное, сэкономил кучу времени. У меня так сходу пока не получается. Первый вариант подойдет.


 
Johnmen ©   (2004-03-15 11:49) [4]

Думается, что так будет быстрее:

SELECT *
FROM Table T1
WHERE T1.date=(SELECT MAX(T2.date)
               FROM Table T2
               WHERE T1.code=T2.code)



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

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

Наверх




Память: 0.47 MB
Время: 0.044 c
3-1079523655
ligor
2004-03-17 14:40
2004.04.11
подключение к DB2 через DBExpress


1-1079930272
Driver
2004-03-22 07:37
2004.04.11
Как реализовать?


1-1080034370
Серж
2004-03-23 12:32
2004.04.11
Использование не визуального компонента в DLL


1-1080131817
sherminator
2004-03-24 15:36
2004.04.11
распечатка файла


3-1081514428
Strela
2004-04-09 16:40
2004.04.11
timeout expired