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

Привет, помогите советом. Очень надо повесить на колонку индексацию, только

одно но, там может быть NULL, clickhouse не дает добавить на эту колонку индекс.
Скорее всего, у вас, профессионалов, уже есть определенные хитрости, как это сделать, можете поделиться? Или все таки никак?

9 ответов

12 просмотров

тип поля? Зачем вам 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 кажется не будет

L-dar- Автор вопроса
Denny [Altinity]
тип поля? Зачем вам null? зависит от версии КХ, е...

Тип поля Int Это поле не обязательное, поэтому там может быть NULL Искать мне нужно как раз по значению, не NULL

L-dar- Автор вопроса
Denny [Altinity]
Ну и храните -999999999999 вместо null

ну да, это первое что мне пришло в голову, но хотел все таки уточнить) Наверное попробую активировать allow_nullable_key Спасибо!

Denny [Altinity]
Ну и храните -999999999999 вместо null

null корректно работает с аггрегирующими столбцами типа anyLatst и не перезатирает там последнее значение, а -999999999999 перезатирает и тогда приходится городить argMax, а он усложняет запросы и больше хранит данных на диске, хотя и полезен при многопоточной вставке, когда нужна гарантия, что значение действительно последнее

Denny [Altinity]
тип поля? Зачем вам null? зависит от версии КХ, е...

allow_nullable_key? Ого, внезапно. А почему оно по дефолту выключено? Какие подводные камни?

Sergey Churin
allow_nullable_key? Ого, внезапно. А почему оно по...

Потому что никто ее не тестировал. И не рекомендуется использовать с точки зрения перфоманса. Кх тормозит.

Sergey Churin
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.

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

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

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
База данных не поможет. Шифрование не поможет. Какие там ещё варианты? Накидывайте.
КТ315
20
А табстоп это сообщение от окна или от элемента управления?
The Bird of Hermes
18
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
Открыл свой двухкилобайтный экзешник в x32dbg, а тут какая-то хрень. Смущает кнопка "выполнить до пользовательского кода", а что ещё может быть в файле помимо него ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
11
Мне были интересны дишные хаки и я нашёл любопытный способ на форуме через __traits, что-то вроде int delegate(int) fac = (int n) => n == 0 ? 1 : n * __traits(parent, {})(n - ...
Constantin F.
1
Вопрос тем кто смотрит видео и слушает подкасты - как вы потом ищете нужную вам информацию? Вот статью я прочитал, потом могу искать нужную мне часть банальным поиском. Пропус...
Aleksandr Druzhinin
4
Всем привет, подскажите/посоветуйте пожалуйста. Фаердак компоненты, имею одно место где бизнес хочет видеть при открытии формы список всех клиентов, это порядка 30к. Мои дово...
Sasha Sch
14
Ребят, если кто в курсе - скажите, а в загранке такое же засилье маркетплейсов? или там простые сермяжные интернет-магазины живут попроще?
Андрей [aharito] Харитонов
14
Коллеги, доброе утро. Запустил на удаленном хосте приложение (ручками зашел туда по ssh и запустил, не командой удаленно). Создал потом ssh-туннель, и с моей машины приложение...
Δημήτηρ
9
Карта сайта