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

Коллеги, добрый день! Создаю через dbt таблицу-справочник в Clickhouse. Clickhouse создает

эту таблицу со всеми полями с типом НЕ Nullable.
Допустим, пусть это и неправильно, что в этом справочнике есть не все значения, которые в таблице фактов могут встречаться.
Я хочу при джойне таблицы фактов и справочника в несовпавших строках получить null. Но Clickhouse им всем проставляет '' (пустоту).

Я новичек с CH, поэтому у меня такой вопрос: вот этот новый столбец, получающийся после джойна, он обязательно будет иметь тот же тип столбца, что и в справочнике? Я бы хотел, чтобы он содержал null, даже если исходный столбец не Nullable.
И как мне это обыграть тогда? Пока только придумал в справочник последней строкой добавлять строку из одних null'ов, чтобы все столбцы были Nullable, но выглядит не как best practice.

4 ответов

6 просмотров

есть настройка которая определяет поведение при джойнах https://clickhouse.com/docs/en/operations/settings/settings#join_use_nulls а что бы сделать колонку Nullable надо в модели явно приводить select toNullable(col) as col. Но Nullable в целом лучше избегать

unhingedlunatic- Автор вопроса

JOIN со справочником замените на dictGetOrNull

unhingedlunatic- Автор вопроса
Slach [altinity]
JOIN со справочником замените на dictGetOrNull

Спасибо за совет, почитаю) словарей пока не касался ☺️

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

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

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Заметил в ghci 9.4.8: > :t (<*>) @((->)_) (<*>) @((->)_) :: (w -> (a -> b)) -> (w -> a) -> w -> b Разве не должно (w -> (a -> b)) быть записано как (w -> a -> b)? Это баг, ил...
Михаил
13
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Any electron dev here?
Sayanth Tezro
12
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
так это может кто что знает или использует что-то как макбук только не макбук? на 13…14 дюймов
Michael
9
;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, стандартный ;вызов процедуры ;option casemap:no...
Егор Анелькин
1
Карта сайта