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

Вопрос попроще: как можно сделать, чтобы во всех строчках значения

были в процентах относительно нулевой строчки?

8 ответов

5 просмотров

только если подзапросом первую строчку достать

в какой версии КХ ? Можно через массивы можно через window functions

Vladimir-Goncharov Автор вопроса
Denny [Altinity]
в какой версии КХ ? Можно через массивы можно чере...

21.3.3.14 пытаюсь сейчас через массивы, пока не очень получается

Vladimir Goncharov
21.3.3.14 пытаюсь сейчас через массивы, пока не оч...

SELECT (arrayJoin(arrayMap(i -> (i, (i / (g[1])) * 100), groupArray(x) AS g)) AS t).1 AS n, t.2 AS per FROM ( SELECT number AS x FROM numbers(10) ORDER BY x DESC ) ┌─n─┬───────────────per─┐ │ 9 │ 100 │ │ 8 │ 88.88888888888889 │ │ 7 │ 77.77777777777779 │ │ 6 │ 66.66666666666666 │ │ 5 │ 55.55555555555556 │ │ 4 │ 44.44444444444444 │ │ 3 │ 33.33333333333333 │ │ 2 │ 22.22222222222222 │ │ 1 │ 11.11111111111111 │ │ 0 │ 0 │ └───┴───────────────────┘

Vladimir-Goncharov Автор вопроса
Denny [Altinity]
SELECT (arrayJoin(arrayMap(i -> (i, (i / (g[1]...

спасибо, работает в 2 раза быстрее чем мой вариант: SELECT arrayJoin(active_days) - toDate(first_activity) as day, 100*uniq(device_id)/max_users as k FROM raw_users FINAL ARRAY JOIN [(SELECT uniq(device_id) as k FROM raw_users FINAL WHERE has(active_days, toDate(first_activity)))] as max_users GROUP BY day,max_users ORDER BY day ASC который я так понимаю рассчитывает значение максимума не один раз, а на каждую строку, аналогично: SELECT arrayJoin(active_days) - toDate(first_activity) as day, 100*uniq(device_id)/(SELECT uniq(device_id) as k FROM raw_users FINAL WHERE has(active_days, toDate(first_activity))) as k FROM raw_users FINAL GROUP BY day ORDER BY day ASC

Vladimir-Goncharov Автор вопроса
Denny [Altinity]
SELECT (arrayJoin(arrayMap(i -> (i, (i / (g[1]...

ещё раз спасибо. а как сделать тоже самое, но с помощью оконных функций. запрос через массивы не получилось впихнуть в концепцию метабейза. есть шансы, что с оконными функциями прокатит.

Vladimir Goncharov
ещё раз спасибо. а как сделать тоже самое, но с по...

SELECT (x / s) * 100 FROM ( SELECT x, any(x) OVER (ORDER BY x DESC ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) AS s FROM ( SELECT number AS x FROM numbers(10) ) ) ┌─multiply(divide(x, s), 100)─┐ │ 100 │ │ 88.88888888888889 │ │ 77.77777777777779 │ │ 66.66666666666666 │ │ 55.55555555555556 │ │ 44.44444444444444 │ │ 33.33333333333333 │ │ 22.22222222222222 │ │ 11.11111111111111 │ │ 0 │ └─────────────────────────────┘

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

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

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
У тебя в конфиге нигде нет deny all; или вообще любого deny?
Alexander Sherbakov
10
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
Есть Pipeline для GitLab Runner (executor = "shell") В нём есть: default: before_script: - set -eo pipefail - source "$(~/bin/trdl use werf 2 stable)" - source...
Aleksandr Karabanov
1
Есть ли смысл устраиваться на 1с ? Даст это плюс в дальнейшем трудоустройстве на php? Просто у меня в городе вакансий на пхп нету. Или лучше удаленно искать. Опыта работы нету...
Azamat
14
Карта сайта