T で許可される通常の値に加えて、「欠損値」を表す特別なマーカー (NULL) を格納できます。たとえば、Nullable(Int8) 型のカラムには Int8 型の値を格納でき、値を持たない行には NULL が格納されます。
T には、次の複合データ型は指定できません。
ただし、複合データ型に Nullable 型の値を含めることはできます。たとえば、Array(Nullable(Int8)) や Tuple(Nullable(String), Nullable(Int64)) です。
実験的機能: Nullable Tuple
allow_experimental_nullable_tuple_type = 1が有効な場合、Nullable(Tuple(…)) がサポートされます。
Nullable 型のフィールドは、テーブルの索引に含めることはできません。
ClickHouse サーバー設定で別途指定されていない限り、NULL はすべての Nullable 型のデフォルト値です。
ストレージ機能
Nullable 型の値を格納するため、ClickHouse は値を格納する通常のファイルに加えて、NULL マスク用の別ファイルを使用します。マスクファイル内のエントリによって、ClickHouse はテーブルの各行について、NULL と対応するデータ型のデフォルト値を区別できます。ファイルが 1 つ追加されるため、Nullable カラムは同等の通常のカラムと比べてより多くのストレージ領域を消費します。
Nullable を使用すると、ほとんどの場合パフォーマンスに悪影響が生じます。データベースを設計する際は、この点を考慮してください。NULL の検出
null サブカラムを使ってカラム内の NULL 値を検出できます。対応する値が NULL の場合は 1、それ以外の場合は 0 を返します。
例
Query
Response