одно но, там может быть NULL, clickhouse не дает добавить на эту колонку индекс.
Скорее всего, у вас, профессионалов, уже есть определенные хитрости, как это сделать, можете поделиться? Или все таки никак?
тип поля? Зачем вам null? зависит от версии КХ, есть параметр allow_nullable_key https://github.com/sevirov/ClickHouse/blob/4da5882bec3e9b4cdc7af9079a259a1563be0ce5/docs/en/operations/settings/settings.md#allow_nullable_key-allow-nullable-key но поиска по индексу where ... is null кажется не будет
Тип поля Int Это поле не обязательное, поэтому там может быть NULL Искать мне нужно как раз по значению, не NULL
Ну и храните -999999999999 вместо null
ну да, это первое что мне пришло в голову, но хотел все таки уточнить) Наверное попробую активировать allow_nullable_key Спасибо!
null корректно работает с аггрегирующими столбцами типа anyLatst и не перезатирает там последнее значение, а -999999999999 перезатирает и тогда приходится городить argMax, а он усложняет запросы и больше хранит данных на диске, хотя и полезен при многопоточной вставке, когда нужна гарантия, что значение действительно последнее
allow_nullable_key? Ого, внезапно. А почему оно по дефолту выключено? Какие подводные камни?
Потому что никто ее не тестировал. И не рекомендуется использовать с точки зрения перфоманса. Кх тормозит.
https://github.com/ClickHouse/ClickHouse/issues/23634#issuecomment-826374602 alexey-milovidov : allow_nullable_key is a nonsense, this setting should not be used in production.
Обсуждают сегодня