mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-04 13:32:13 +00:00
26 lines
1.8 KiB
Markdown
26 lines
1.8 KiB
Markdown
---
|
||
slug: /ru/sql-reference/statements/alter/index
|
||
toc_hidden_folder: true
|
||
sidebar_position: 42
|
||
sidebar_label: "Манипуляции с индексами"
|
||
---
|
||
|
||
# Манипуляции с индексами {#manipuliatsii-s-indeksami}
|
||
|
||
Добавить или удалить индекс можно с помощью операций
|
||
|
||
``` sql
|
||
ALTER TABLE [db.]table_name [ON CLUSTER cluster] ADD INDEX name expression TYPE type GRANULARITY value [FIRST|AFTER name]
|
||
ALTER TABLE [db.]table_name [ON CLUSTER cluster] DROP INDEX name
|
||
ALTER TABLE [db.]table_name [ON CLUSTER cluster] MATERIALIZE INDEX name IN PARTITION partition_name
|
||
```
|
||
|
||
Поддерживается только таблицами семейства `*MergeTree`.
|
||
|
||
Команда `ADD INDEX` добавляет описание индексов в метаданные, а `DROP INDEX` удаляет индекс из метаданных и стирает файлы индекса с диска, поэтому они легковесные и работают мгновенно.
|
||
|
||
Если индекс появился в метаданных, то он начнет считаться в последующих слияниях и записях в таблицу, а не сразу после выполнения операции `ALTER`.
|
||
`MATERIALIZE INDEX` - перестраивает индекс в указанной партиции. Реализовано как мутация. В случае если нужно перестроить индекс над всеми данными то писать `IN PARTITION` не нужно.
|
||
|
||
Запрос на изменение индексов реплицируется, сохраняя новые метаданные в ZooKeeper и применяя изменения на всех репликах.
|