170 похожих чатов

Чуваки, помогите советом. Есть таблица куда падают числовые значения статистики

каждую минуту. Нужно группировать эти значения в среднее за 10 минут (хранится 12 часов), час (хранится день) и за день (остается навсегда). С группировкой проблем нет. Вопрос как хранить группированные значения? Учитывая то, что все средние значения меньше чем за день, хранятся в базе ограниченное кол-во времени. Я думал хранить все в отдельных таблицах разделенных по периоду группировки, но мне нужно выводить график этих значений и появляется сложность с тем, когда когда например нужно вывести график значений за последнюю неделю. В нем самые свежие значения за минуту, потом за 10 мин, потом по часам и далее уже по дням. Надеюсь понятно объяснил, уверен этот велосипед уже изобретен до меня.

3 ответов

3 просмотра

а может оставить как есть и кэшировать результаты?

в идеале как посоветовали юзать InfluxDB/ClickHouse но если нам надо - сделать сейчас - не переписать пол системы - не хочется сейчас изучать и подключать новые технологии - это неприоритетной задача для бизнеса можно подумать как сделать лучше с минимальными усилиями как по мне нужно разделить значения по выборке  - добавить enum time_period с значениями 10 мин, 1 час, 12 часов и т.д. (лучше на уровне бд сделать беззнаковый инт чтоб без проблем добавлять значения периодов) - добавить период в индекс - при выборке ставить ключ нужного периода таким образом решена проблема как отличать сгрупированые значения и измерения + скорость должна быть в норме также когда график увеличивают можем делать запрос для меньшего периода  конечно специализированные решения позволять намного более ефективно манипулировать такими данными, но это не всегда нужно

Beeyev- Автор вопроса

Спасибо, хороший вариант

Похожие вопросы

Обсуждают сегодня

Ребят в СИ можно реализовать ООП?
Николай
32
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный  TFilestream  не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
16
У меня задача: написать брокер сообщений. Очереди и потребители. Очереди поддерживают приоритеты. Очередь отдает сообщения, только обработчикам с соответствующими характеристи...
Aleksandr Filippov
2
добрый день. Подскажите, есть сайт на 1.4.7 и я хочу обновиться, особо ничего не меняя. мне выбирать версию 1.4.35 или третью ветку? и можно ли обновлять "как есть", или нужно...
Digital Cat
12
народ, плиз хелп, всю голову сломал себе уже... разве может быть так, что GetProcAddress( GetModuleHandle( "kernel32.dll" ), "SetThreadDescription" ) вернёт ненулевое значение...
Iluha Companets
12
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный TFilestream не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
8
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Карта сайта