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

estimateCompressionRatio

estimateCompressionRatio

Оценивает коэффициент сжатия заданной колонки без её сжатия.

Синтаксис

estimateCompressionRatio(codec, block_size_bytes)(column)

Аргументы

  • column - Колонка любого типа

Параметры

  • codec - Строка, содержащая кодек сжатия или несколько кодеков, разделённых запятыми в одной строке.
  • block_size_bytes - Размер блока сжатых данных. Это аналогично настройкам max_compress_block_size и min_compress_block_size. Значение по умолчанию — 1 MiB (1048576 байт).

Оба параметра являются необязательными.

Возвращаемые значения

  • Возвращает оценку коэффициента сжатия для данной колонки.

Тип: Float64.

Примеры

CREATE TABLE compression_estimate_example
(
    `number` UInt64
)
ENGINE = MergeTree()
ORDER BY number
SETTINGS min_bytes_for_wide_part = 0;

INSERT INTO compression_estimate_example
SELECT number FROM system.numbers LIMIT 100_000;
SELECT estimateCompressionRatio(number) AS estimate FROM compression_estimate_example;
┌───────────estimate─┐
│ 1.9988506608699999 │
└────────────────────┘
примечание

Результат выше будет различаться в зависимости от кодека сжатия по умолчанию на сервере. См. Кодеки сжатия колонок.

SELECT estimateCompressionRatio('T64')(number) AS estimate FROM compression_estimate_example;
┌──────────estimate─┐
│ 3.762758101688538 │
└───────────────────┘

Функция также может указывать несколько кодеков:

SELECT estimateCompressionRatio('T64, ZSTD')(number) AS estimate FROM compression_estimate_example;
┌───────────estimate─┐
│ 143.60078980434392 │
└────────────────────┘