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

Вниз

Хитрый SELECT   Найти похожие ветки 

 
Delphile   (2007-06-13 18:01) [0]

Вроде простая задача, а что-то не получается((
Есть таблица со значениями счетчиков. Поля:

ID, CounterID, ValueDate, Value

Нужно запросом выбрать последние значения для каждого счетчика(т.е. с максимальной датой снятия показаний)  и получить что-то вроде

CounterID, LastValue


 
b z   (2007-06-13 18:14) [1]


> Delphile   (13.06.07 18:01)

а что конкретно не получается? покажите ваши пробы


 
Плохиш ©   (2007-06-13 18:16) [2]

select counterid, max(value) as lastvalue from ... group by counterid

это надо что ли? И в чём здесь хитрость?


 
Johnmen ©   (2007-06-13 21:10) [3]


> Плохиш ©   (13.06.07 18:16) [2]

Я думаю, что последние показания это те Value, у которых макс. ValueDate для соотв-их CounterID.

И здесь ничего хитрого. Такой вопрос здесь появляется каждую неделю. Зачетную или экзаменационную...:)


 
Delphile   (2007-06-13 22:51) [4]


> b z   (13.06.07 18:14) [1]
>
> > Delphile   (13.06.07 18:01)
>
> а что конкретно не получается? покажите ваши пробы
> <Цитата>
>
>
> Плохиш ©   (13.06.07 18:16) [2]
> select counterid, max(value) as lastvalue from ... group
> by counterid
>
> это надо что ли? И в чём здесь хитрость?


Вот вобщем-то все к чему я пришел, но это ведь не то что задано. Значение счетчика может в общем случае уменьшаться. Интересует как правильно решать такие задачи средствами SQL. Таблицы очень большие и это не зачет и не экзамен кстати.


 
Johnmen ©   (2007-06-13 23:11) [5]

SELECT * FROM Table T1
WHERE T1.ValueDate=
 (SELECT MAX(T2.ValueDate) FROM Table T2
  WHERE T2.CounterID=T1.CounterID)


 
Delphile   (2007-06-13 23:42) [6]

Очень изящно.  И план в одну линию. Я нагородил поболее. хотя планы одинаковые. Спасибо всем

select cv.CounterID, cv.Value LastValue
from CounterValue cv
join (select CounterID, max(ValueDate) LastDate
 from CounterValue  
 group by CounterID) cvd on cv.CounterID = cvd.CounterID
where cvd.LastDate = cv.ValueDate


 
Delphile   (2007-06-13 23:44) [7]

это было на


> Johnmen ©   (13.06.07 23:11) [5]



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

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

Наверх




Память: 0.48 MB
Время: 0.354 c
2-1191265539
Farel
2007-10-01 23:05
2007.10.21
Blob


2-1190726011
Yurikon
2007-09-25 17:13
2007.10.21
Вопрос по RecNO


15-1190451190
РВА
2007-09-22 12:53
2007.10.21
Где взять ключ для Turbo Delphi


2-1191175017
Pacific
2007-09-30 21:56
2007.10.21
WebBrowser1


2-1190788195
Alex7
2007-09-26 10:29
2007.10.21
Как обработать одно Field (DateTime) в двух Column Date и Time