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

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

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

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

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

MergeTree

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

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

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

Log

Легковесные движки с минимальной функциональностью. Они наиболее эффективны, когда необходимо быстро записать много небольших таблиц (до approximately 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 * не возвращает значения из виртуальных колонок.

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