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

Подскажите плиз, для time-series есть какой-то синтаксический шугар, чтобы переходы

(последовательные пары) считать? Или надо не мудрить и делать оконными функциями.

Например, из первой таблички получить второй датасет:

insert into events (id, user, event) values
(1, 'alan', 'init'),
(2, 'alan', 'login'),
(3, 'bob', 'init'),
(4, 'alan', 'checkpoint'),
(5, 'bob', 'login'),
(6, 'alan', 'checkpoint'),
(7, 'bob', 'logout'),
(8, 'bob', 'login'),
(9, 'alan', 'logout'),
(10, 'bob', 'logout');

init -> login: 2
login -> checkpoint: 1
checkpoint -> checkpoint: 1
login -> logout: 2
logout -> login: 1
checkpoint -> logout: 1

3 ответов

17 просмотров

Думаю чего то особого нет, впрочем на оконках это достаточно тривиально делается (одна LAG)

https://clickhouse.com/docs/en/sql-reference/aggregate-functions/parametric-functions/#windowfunnel

Konstantin Sevastianov
https://clickhouse.com/docs/en/sql-reference/aggre...

Через оконку будет лучше, не нужно будет перечислять все возможные комбинации самостоятельно

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
5
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Карта сайта