Skip to main content
Skip to main content
Edit this page

Column Types

See Data Types for general reference.

Numeric types

Tip

Numeric types encoding matches memory layout of little endian CPUs like AMD64 or ARM64.

This allows to implement very efficient encoding and decoding.

Integers

String of Int and UInt of 8, 16, 32, 64, 128 or 256 bits, in little endian.

Floats

Float32 and Float64 in IEEE 754 binary representation.

String

Just an array of String, i.e. (len, value).

FixedString(N)

An array of N-byte sequences.

IP

IPv4 is alias of UInt32 numeric type and represented as UInt32.

IPv6 is alias of FixedString(16) and represented as binary directly.

Tuple

Tuple is just an array of columns. For example, Tuple(String, UInt8) is just two columns encoded continuously.

Map

Map(K, V) consists of three columns: Offsets ColUInt64, Keys K, Values V.

Rows count in Keys and Values column is last value from Offsets.

Array

Array(T) consists of two columns: Offsets ColUInt64, Data T.

Rows count in Data is last value from Offsets.

Nullable

Nullable(T) consists of Nulls ColUInt8, Values T with same rows count.

// Nulls is nullable "mask" on Values column.
// For example, to encode [null, "", "hello", null, "world"]
// Values: ["", "", "hello", "", "world"] (len: 5)
// Nulls: [ 1, 0, 0, 1, 0] (len: 5)

UUID

Alias of FixedString(16), UUID value represented as binary.

Enum

Alias of Int8 or Int16, but each integer is mapped to some String value.

Low Cardinality

LowCardinality(T) consists of Index T, Keys K, where K is one of (UInt8, UInt16, UInt32, UInt64) depending on size of Index.

// Index (i.e. dictionary) column contains unique values, Keys column contains
// sequence of indexes in Index column that represent actual values.
//
// For example, ["Eko", "Eko", "Amadela", "Amadela", "Amadela", "Amadela"] can
// be encoded as:
// Index: ["Eko", "Amadela"] (String)
// Keys: [0, 0, 1, 1, 1, 1] (UInt8)
//
// The CardinalityKey is chosen depending on Index size, i.e. maximum value
// of chosen type should be able to represent any index of Index element.

Bool

Alias of UInt8, where 0 is false and 1 is true.