Перейти к основному содержимому
Перейти к основному содержимому

Движки таблиц

Движок таблицы (тип таблицы) определяет:

  • Как и где хранятся данные, куда их записывать и откуда их читать.
  • Какие запросы поддерживаются и как.
  • Одновременный доступ к данным.
  • Использование индексов, если они есть.
  • Возможность многопоточного выполнения запросов.
  • Параметры репликации данных.

Семейства движков

MergeTree

Наиболее универсальные и функциональные движки таблиц для задач с высокой нагрузкой. Общим свойством этих движков является быстрая вставка данных с последующей обработкой данных в фоновом режиме. Движки семейства MergeTree поддерживают репликацию данных (с Replicated* версиями движков), партиционирование, вторичные индексы для пропуска данных и другие функции, не поддерживаемые в других движках.

Движки в семействе:

Движки MergeTree
MergeTree
ReplacingMergeTree
SummingMergeTree
AggregatingMergeTree
CollapsingMergeTree
VersionedCollapsingMergeTree
GraphiteMergeTree

Log

Легковесные движки с минимальной функциональностью. Они наиболее эффективны, когда необходимо быстро записать много маленьких таблиц (до примерно 1 миллиона строк) и прочитать их позднее целиком.

Движки в семействе:

Движки Log
TinyLog
StripeLog
Log

Интеграционные движки

Движки для взаимодействия с другими системами хранения и обработки данных.

Движки в семействе:

Интеграционные движки
ODBC
JDBC
MySQL
MongoDB
Redis
HDFS
S3
Kafka
EmbeddedRocksDB
RabbitMQ
PostgreSQL
S3Queue
TimeSeries

Специальные движки

Движки в семействе:

Специальные движки
Distributed
Dictionary
Merge
Executable
File
Null
Set
Join
URL
View
Memory
Buffer
External Data
GenerateRandom
KeeperMap
FileLog

Виртуальные колонки

Виртуальная колонка — это неотъемлемый атрибут движка таблицы, который определяется в исходном коде движка.

Вы не должны указывать виртуальные колонки в запросе CREATE TABLE, и вы не можете их увидеть в результатах запросов SHOW CREATE TABLE и DESCRIBE TABLE. Виртуальные колонки также только для чтения, поэтому вы не можете вставить данные в виртуальные колонки.

Чтобы выбрать данные из виртуальной колонки, вы должны указать её имя в запросе SELECT. SELECT * не возвращает значения из виртуальных колонок.

Если вы создаёте таблицу с колонкой, имеющей то же имя, что и одна из виртуальных колонок таблицы, виртуальная колонка становится недоступной. Мы не рекомендуем этого делать. Чтобы избежать конфликтов, имена виртуальных колонок обычно начинаются с подчеркивания.