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 ответов

20 просмотров

да вроде оба работают 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,

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

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

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

#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
Карта сайта