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

Привет, А есть какой-нибудь адекватный способ считать длительности цепочек событий? Допустим, есть

у меня таблица (ts, session_id, event (START/SOMETHING/END))
и я хочу посчитать среднюю по больнице (среднее время между START-END внутри одной сессии, например)

есть ли какой-нибудь изящный способ это сделать? пока думал над следующими вариантами:
* запилить адовую аггрегацию с array-функциями и group by csid - не хватает оперативки
* запилить SummingMergeTree (csid, ts_buffer, counter), по событию START вставлять туда (csid, ts, 1), по событию END вставлять туда (csid, -ts, 1). Вроде должно работать очень быстро, но тут не ясно, что делать, когда counter%2!=0 (придется отбрасывать все данные, даже если там какие-то другие есть)

11 ответов

13 просмотров

и что у session_id всегда одна пара start stop ?

Aleksei-Kh Автор вопроса
Aleksei Kh
может быть несколько

тогда только запросы с массивами

Aleksei-Kh Автор вопроса
Aleksei Kh
адъ, но спасибо

ну так а например как вы такое сделате в mysql ? или pg? или кассандре? надо данные готовить а не бездумно пихать все в базу в непригодном для запросов виде

Aleksei-Kh Автор вопроса
Denny [Altinity]
ну так а например как вы такое сделате в mysql ? и...

сейчас что-то такое делает адовая куча сервисов, которая делает это все в памяти :) там и scylla, и elasticsearch. по всем пунктам согласен, этого в принципе и добиваюсь

Aleksei-Kh Автор вопроса
Denny [Altinity]
тогда только запросы с массивами

так, а если может быть только одна пара событий - есть решение эффективнее?

Aleksei Kh
так, а если может быть только одна пара событий - ...

session_id, minIf(event=start) b, maxIf(event=stop) e , e-b group by session_id

Aleksei-Kh Автор вопроса
Denny [Altinity]
session_id, minIf(event=start) b, maxIf(event=stop...

ну в принципе мой вариант для нескольких пар событий через sumIf(±ts) практически так же работает. только будут проблемы, если будет много непарных событий. думаю, жить можно

Aleksei-Kh Автор вопроса
Aleksei Kh
ну в принципе мой вариант для нескольких пар событ...

хотя можно поверх запилить anyLastIf(counter%2==0, sum)

Aleksei-Kh Автор вопроса

вот кстати deltaSum появился еще, как будто бы сам просил

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

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

#include <stdio.h> #include <stdlib.h> #include <time.h> void mass_first_generate(int mass[5][7]) {     for (int N = 0; N < 5; N++) {         for (int A = 0; A < 7; A++) {   ...
Чувак
6
https://www.linkedin.com/posts/ugama-benedicta-kelechi-codergirl-103041300_mobiledevelopment-fluttertraining-handsonlearning-activity-7263445699227254784-IdHB?utm_source=share...
CoderGirl
16
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Помогите пожалуйста. Делаю систему плагинов. Проблема сейчас в такая: плагины загружаются в основном потоке. FLibHandle := SafeLoadLibrary(FFileName) Но нужно еще выполнить фу...
Илья 🤣
10
Ну вот просто даже давайте вот как. Какой нибудь конкретный кейс, можете в пример привести, где бч работает и приносит прикладную пользу, а не просто что бы было? Не крипту.
Alexander Andreev
22
объясните пожалуйста, почему функция не работает должным образом? вроде должно брать активное окно сравнивать его размер с размером экрана, и если есть совпадение = true прове...
JF
12
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
Гляньте, че бывает: Сегодня по одному проекту одной вебстудии делал проект небольшой, на их хостинге. На Modx revo. В определенный момент , работая в админке, вдруг перестал р...
Artem
7
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
12
> Копаем глубже > Следующий момент был, когда я спросил его, знает ли он JavaScript. Он ответил, что его учили работать с C#. Я тоже в университете писал на C#, но даже там мн...
Oleg Volkov
4
Карта сайта