Манипулирование индексами пропуска данных
Доступны следующие операции:
ДОБАВИТЬ ИНДЕКС
ALTER TABLE [db.]table_name [ON CLUSTER cluster] ADD INDEX [IF NOT EXISTS] name expression TYPE type [GRANULARITY value] [FIRST|AFTER name]
- Добавляет описание индекса в метаданные таблиц.
УДАЛИТЬ ИНДЕКС
ALTER TABLE [db.]table_name [ON CLUSTER cluster] DROP INDEX [IF EXISTS] name
- Удаляет описание индекса из метаданных таблиц и удаляет файлы индекса с диска. Реализовано как мутация.
МАТЕРИАЛИЗОВАТЬ ИНДЕКС
ALTER TABLE [db.]table_name [ON CLUSTER cluster] MATERIALIZE INDEX [IF EXISTS] name [IN PARTITION partition_name]
- Перестраивает вторичный индекс name
для указанной partition_name
. Реализовано как мутация. Если часть IN PARTITION
опущена, то индекс перестраивается для всех данных таблицы.
ОЧИСТИТЬ ИНДЕКС
ALTER TABLE [db.]table_name [ON CLUSTER cluster] CLEAR INDEX [IF EXISTS] name [IN PARTITION partition_name]
- Удаляет файлы вторичного индекса с диска, не удаляя описание. Реализовано как мутация.
Команды ADD
, DROP
и CLEAR
являются легковесными в том смысле, что они изменяют только метаданные или удаляют файлы. Также они реплицируются, синхронизируя метаданные индексов через ClickHouse Keeper или ZooKeeper.
Манипулирование индексами поддерживается только для таблиц с движком *MergeTree
(включая реплицированные варианты).