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

Всем привет, а напомните плз, в CH схема таблицы должна

быть известна заранее или новые колонки могут добавляться в рантайме?
Идея в том, чтобы при добавлении новых событий с новой структурой не выполнять скрипт миграции c alter table.

15 ответов

7 просмотров

Для типа JSON в рантайме можно новое добавлять, а так нет, нужно заранее структуру определить. Но стоит отметить, что добавление новой колонки в ClickHouse это очень дешевая операция, обычно не больше пары секунд занимает

вы базы данных с чем то путаете

rdcm- Автор вопроса
Sergey Platonov
вы базы данных с чем то путаете

ну в смысле, в mongodb например можно писать данные в коллекцию любой структуры которая определена на уровне приложения думал в CH так же можно

можно только если поле определено как мапа и с ней можно условно как с json отработать. Правда там с произвольной вложенностью проблемы

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

а есть линк на доку?

Есть тип данных JSON, в который можно вставлять любой JSON (но тип конкретных полей меняться не должен). Правда не использовал его на практике, поэтому не подскажу, насколько оно хорошо работает.

rdcm
а есть линк на доку?

https://clickhouse.com/docs/en/sql-reference/data-types/map

rdcm- Автор вопроса
Yuran
Есть тип данных JSON, в который можно вставлять лю...

у ch с json почему-то плохо на практике, вроде мне в этом чате разработчик отвечал, что планируют в следующем году допилить, пока это экспериментальная фича

rdcm
у ch с json почему-то плохо на практике, вроде мне...

и есть такое https://clickhouse.com/docs/en/integrations/data-formats/json

rdcm- Автор вопроса
Tetra
и есть такое https://clickhouse.com/docs/en/integr...

угумс, для моей задачи наверное не совсем то, уже пробовал

rdcm
у ch с json почему-то плохо на практике, вроде мне...

В таком случае нет, ClickHouse так не умеет. Но в качестве альтернативы можно вставлять в String поле исходный JSON и потом постфактум создавать материализованные колонки вида fieldName Int64 MATERIALIZED extractJsonInt64(json_column), Чтобы поиск по этим полям был быстрее

rdcm- Автор вопроса
Tetra
а чем не подошло?

контекст немного ушел, но примерно из-за этого: - сыроватый функционал с багами - не во всех view поддержана колонка с типом json - в целом нет такой необходимости, подойдёт просто широкая плоская таблица на N столбцов

rdcm- Автор вопроса
Yuran
В таком случае нет, ClickHouse так не умеет. Но в ...

В общем это тоже ответ, спасибо 🙂 Думаю можно от-но элегантно обойти

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

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

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