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

CREATE OR REPLACE TABLE test ( `type` LowCardinality(String),

`time` DateTime64(3) CODEC(DoubleDelta),
`psid` String,
`paused` UInt8
)
ENGINE = MergeTree
ORDER BY (time, xxHash64(psid));

insert into test (type, time, psid, paused) values
('TYPE1', now64(), 'PSID1', 1),
('TYPE2', now64(), 'PSID1', 1),
('TYPE1', now64(), 'PSID1', 0),
('TYPE2', now64(), 'PSID1', 0),
('TYPE1', now64(), 'PSID2', 0),
('TYPE1', now64(), 'PSID2', 0),
('TYPE1', now64(), 'PSID2', 0),
('TYPE2', now64(), 'PSID2', 0),
('TYPE1', now64(), 'PSID2', 1),
('TYPE1', now64(), 'PSID2', 0),
('TYPE1', now64(), 'PSID2', 0),
('TYPE1', now64(), 'PSID2', 0)
;

-- работает
select
row_number() over w as rn,
sum(paused) over w as cnt_paused,
*
from test e
where psid = 'PSID2'
window w as (partition by e.psid order by e.time)

-- не работает:
-- DB::Exception: Column `type` is not under aggregate function and not in GROUP BY: While processing row_number() OVER w AS rn, countIf(paused = 1) AS cnt_paused, type, time, psid, paused. (NOT_AN_AGGREGATE)
select
row_number() over w as rn,
sumIf(1, paused=1) over w as cnt_paused,
*
from test e
where psid = 'PSID2'
window w as (partition by e.psid order by e.time)
подскажите пожалуйста по window functions. если первый запрос работает, почему второй нет? я чего-то не понимаю?
отличие одно: в первом sum(paused), во втором sumIf(1, paused=1). в реальности запрос посложенее, но суть та же

9 ответов

24 просмотра

да вроде оба работают SELECT row_number() OVER w AS rn, sumIf(1, paused = 1) OVER w AS cnt_paused, * FROM test AS e WHERE psid = 'PSID2' WINDOW w AS (PARTITION BY e.psid ORDER BY e.time ASC) Query id: 9c95e165-c1c9-4da4-a7ad-4eec209a09b9 ┌─rn─┬─cnt_paused─┬─type──┬────────────────────time─┬─psid──┬─paused─┐ │ 1 │ 1 │ TYPE1 │ 2021-12-27 14:25:03.400 │ PSID2 │ 0 │ │ 2 │ 1 │ TYPE1 │ 2021-12-27 14:25:03.400 │ PSID2 │ 0 │ │ 3 │ 1 │ TYPE1 │ 2021-12-27 14:25:03.400 │ PSID2 │ 0 │ │ 4 │ 1 │ TYPE2 │ 2021-12-27 14:25:03.400 │ PSID2 │ 0 │ │ 5 │ 1 │ TYPE1 │ 2021-12-27 14:25:03.400 │ PSID2 │ 1 │ │ 6 │ 1 │ TYPE1 │ 2021-12-27 14:25:03.400 │ PSID2 │ 0 │ │ 7 │ 1 │ TYPE1 │ 2021-12-27 14:25:03.400 │ PSID2 │ 0 │ │ 8 │ 1 │ TYPE1 │ 2021-12-27 14:25:03.400 │ PSID2 │ 0 │ └────┴────────────┴───────┴─────────────────────────┴───────┴────────┘ 8 rows in set. Elapsed: 0.003 sec.

Aleksei-Kh Автор вопроса
Denny [Altinity]
да вроде оба работают SELECT row_number() OVE...

какая версия? я проверил в 21.12.2 и 21.4.4

Aleksei-Kh Автор вопроса
Denny [Altinity]
select namt,value from system.settings whree chang...

Connected to ClickHouse server version 21.12.2 revision 54452. localhost :) select name,value from system.settings where changed ┌─name─────────────┬─value───────┐ │ load_balancing │ random │ │ max_memory_usage │ 10000000000 │ └──────────────────┴─────────────┘

Aleksei Kh
Connected to ClickHouse server version 21.12.2 rev...

похоже потом исправили в 21.13

Aleksei-Kh Автор вопроса
Aleksei Kh
уфф, спасибо

вам кстати не нужен if

Aleksei Kh
уфф, спасибо

просто sum(paused = 1) OVER w AS cnt_paused,

Aleksei-Kh Автор вопроса
Denny [Altinity]
просто sum(paused = 1) OVER w AS cnt_paused,

это хуже, оно на реальных данных работает, но дает неадекватные значения

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта