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

Други, а подскажите, плиз, есть ли какие-то преимущества делать словари

на мелкие таблицы (до 10K записей), при условии, что и таблицы и словари хранятся в clickhouse-е, чтоб потом эти словари можно было джойнить к основной таблице (a-la классическая звезда)?

Например,
CREATE TABLE t_client (
id UInt32 CODEC(ZSTD),
name LowCardinality(String) CODEC(ZSTD),
)
ENGINE = MergeTree()
ORDER BY (id)

CREATE DICTIONARY d_client
(
id UInt32,
name String,
)
PRIMARY KEY id
SOURCE(CLICKHOUSE(TABLE 't_client'))
LIFETIME(60)
LAYOUT(FLAT(INITIAL_ARRAY_SIZE 50 MAX_ARRAY_SIZE 1000))

Какой-либо существенной разницы между джойном таблицы напрямую или джойном со словарем не заметил

SELECT *
FROM t_event e
JOIN t_client c ON e.client_id = c.id

SELECT *
FROM t_event e
JOIN d_client c ON e.client_id = c.id

6 ответов

12 просмотров

никакого смысла словари хеш таблицы... по которым надо делать dictGet а не JOIN ... с JOIN обычные таблицы быстрее работать будут...

у вас данных значит не много... словари так себе итерируются...

Sergey Zhemzhitsky
а что значит итерируются?

перебирает, подряд хеш таблица не очень для такого предназначена...

Sergey-Zhemzhitsky Автор вопроса

разве dictGet и join на словарь - это не одно и то же? https://github.com/ClickHouse/ClickHouse/pull/10133

Sergey Zhemzhitsky
разве dictGet и join на словарь - это не одно и то...

этот pull request добавил именно саму возможность сделать JOIN со словарем... до него нельзя было, ошибку сказал бы типа table not exists или что-то такое... IMHO нет, не тоже самое dictGet самый быстрый интерфейс к словарям. особенно если они в памяти... он o(1) на каждую строку JOIN dictionary будет ли o(1) при JOIN dictioanry не знаю...то есть на небольших словарях не должно быть вообще заметно разницы... а на словарях в десятки миллионов элементов, должно быть видно попробуйте сравните

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

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

Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
> Копаем глубже > Следующий момент был, когда я спросил его, знает ли он JavaScript. Он ответил, что его учили работать с C#. Я тоже в университете писал на C#, но даже там мн...
Oleg Volkov
4
И никого не интересует какие пакеты кто использует. ((% Заходишь на сайт симфони и видишь поддержку Украины - по законам РФ это ж экстремизм. Только никто не отказывается от с...
Am Ambrion
11
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
Чтобы перехватить все нажимания буков на форме, надо хук ставить? Пробовал на форме ОнКейДаун, оно ловит клаву если фокус не на компоненте с вводом текста
Serjone
15
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
7
Народ! Впервые клиенту пришло письмо от РКН, у вас, дескать, есть яндекс метрика, а нигде не написано, что вы ее юзаете. Никто не сталкивался?
Sasha Beep
14
Всем привет! вывожу на общей стр дочерние ресурсыв каждом ресурсе галерея, и первая фотка должна выводиться на общей [!DocLister? &prepare=photo !]
Alekso
12
А можно вопрос? Мне сегодня сказали что у меня функция (которая просто заполняет массив значениями) не правильная void Full(double * arr, int n) { for (int i = 0; i < n; i...
† C E †
7
Добрый вечер. Хочу чтобы у меня в классе поле было функцией, которая возвращает строку. Делаю так: interface ... TGetOutPath = function : String of object; ... protec...
Kirill Filippenok
12
Карта сайта