Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как подсчитать время? 
:(
    Опции темы
dell23
Дата 26.9.2013, 11:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 1
Регистрация: 26.9.2013

Репутация: нет
Всего: нет



Подскажите пожалуйста с запросом или алгоритмом.
Имеется таблица, в которую записывается включения и отключения насоса. Записывается время (в секундах от эпохи Unix) и действие, "вкл" или "выкл" насос. Нужно посчитать, сколько работал насос. Но проблема в том, что часто записываются ошибочые показания, например:
1300 вкл
1350 выкл
1370 вкл
1400 вкл
1430 вкл
1470 выкл
здесь ошибочно были записаны значения 1400 и 1430. Как составить такой запрос, который бы учитывал только пары значений "вкл"-"выкл"? Т.е. повторяющиеся действия нужно игнорировать.
PM MAIL   Вверх
Akina
Дата 26.9.2013, 11:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 45
Всего: 454



Составь запрос на удаление ошибочных записей. И выполни его. А потом уже считай на чистых данных.


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
Zloxa
Дата 26.9.2013, 12:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 53
Всего: 161



Код

  8   select sum(tm)
  9   from(
 10     select time -  lag(case when op!='выкл' then time end) over (order by time) tm
 11     from t
 12   )
 13  /
   SUM(TM)
----------
       150



Должно работать для MS, оракли, постргиса

Это сообщение отредактировал(а) Zloxa - 26.9.2013, 14:05


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Составление SQL-запросов | Следующая тема »


 




[ Время генерации скрипта: 0.0629 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.