Главная страница
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.015 c
2-1191156516
Kostya2x
2007-09-30 16:48
2007.10.21
Разбор текста с "тегами" и вывод его на RichEdit


15-1190382560
мастерПакость
2007-09-21 17:49
2007.10.21
проблемы с HTML


2-1190813292
Kolan
2007-09-26 17:28
2007.10.21
Научите как сделать ToolBar как в D7


15-1190313580
Int128
2007-09-20 22:39
2007.10.21
Почему в крупе заводятся насекомые?


6-1172154994
vlad_55
2007-02-22 17:36
2007.10.21
HTML-формы