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

Просуммирую Есть, очень грубо говоря, биржевые котировки Они образуют четырехмерное пространство 1. Ось

времени
2. Ось - id грубо говоря акции
3. Ось - название поля (цена, цена открытия, цена закрытия)
4. Ось - resolution (по определенным причинам нужно их хранить раздельно, можете считать это просто категориальным признаком)

cardinaliry оси 1 - сотни-тысяч - единицы миллионов
cardinality оси 2 - порядка 200-300 тысяс
cardinality оси 3 - меньше тысячи (сотни)
cardinality оси 4 - около десятка
Значения - integer, float, string, зависит от оси (3)

Нужно придумать схему хранения в clickhouse, с учетом ее сильных и слабых сторон

Судя по всему, заводить отдельную табличку на каждое значение оси (4) - хорошая идея, отлично, минус одно измерение
Дальше можно ось (3) развернуть в колонки - отлично, минус еще одно измерение

Остаются ось времени и ось инструмента, их я не понимаю как разложить правильно
Складывать тройками (timestamp, security_id, value)?

1 ответов

4 просмотра

мне кажется что неплохим вариантом для начала будет таблица security_id time field_1 field_2 ...т.е. "широкая" таблица с типизированной схемой, если у вас количество полей более менее стабильная величина. date(time) добавить в mergetree в то место, где требуется дата, и (security_id, time) в ключ.

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

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

Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
38
Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
65
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
24
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
Хтось використовував Vapor на Windows?
Jaroshevskii
15
Тут кста кто-нибудь NeoVim использует?
Simple Sorcerer
13
А чем вам питонисты не угодили?😂
.
79
у меня вопрос на счет .global <name> для чего это нужно если я пишу на ассемблере? только для того что бы сделать это видимым для линкера? вот что написано в докумментации GA...
Simple Sorcerer
1
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
У меня вот только только был затык при изучении одной темы. Я настолько привык к джс, что мозг с трудом признал таки, что f и \x -> f x - это равные функции. Потому что в д...
xfides Barabanov
7
Карта сайта