Skip to main content
Edit this page

UUID

UUID(UUID)は、16バイトの値で、レコードを識別するために使用されます。UUIDに関する詳細は、Wikipediaを参照してください。

異なるUUIDのバリアントが存在する一方で(こちらを参照)、ClickHouseは挿入されたUUIDが特定のバリアントに準拠しているかを検証しません。UUIDは内部的には16バイトのランダムなシーケンスとして扱われ、SQLレベルでは8-4-4-4-12の表現を使用します。

UUID値の例:

61f0c404-5cb3-11e7-907b-a6006ad3dba0

デフォルトのUUIDはすべてゼロです。これは、例えば新しいレコードが挿入される際にUUIDカラムに値が指定されていない場合に使用されます。

00000000-0000-0000-0000-000000000000

歴史的な理由により、UUIDはその後半部分でソートされます。したがって、主キー、ソートキー、またはテーブルのパーティションキーに直接UUIDを使用すべきではありません。

例:

CREATE TABLE tab (uuid UUID) ENGINE = Memory;
INSERT INTO tab SELECT generateUUIDv4() FROM numbers(50);
SELECT * FROM tab ORDER BY uuid;

結果:

┌─uuid─────────────────────────────────┐
│ 36a0b67c-b74a-4640-803b-e44bb4547e3c │
│ 3a00aeb8-2605-4eec-8215-08c0ecb51112 │
│ 3fda7c49-282e-421a-85ab-c5684ef1d350 │
│ 16ab55a7-45f6-44a8-873c-7a0b44346b3e │
│ e3776711-6359-4f22-878d-bf290d052c85 │
│ [...] │
│ 9eceda2f-6946-40e3-b725-16f2709ca41a │
│ 03644f74-47ba-4020-b865-be5fd4c8c7ff │
│ ce3bc93d-ab19-4c74-b8cc-737cb9212099 │
│ b7ad6c91-23d6-4b5e-b8e4-a52297490b56 │
│ 06892f64-cc2d-45f3-bf86-f5c5af5768a9 │
└──────────────────────────────────────┘

代替策として、UUIDを直感的なソート順序を持つ型に変換できます。

UInt128への変換を使用した例:

CREATE TABLE tab (uuid UUID) ENGINE = Memory;
INSERT INTO tab SELECT generateUUIDv4() FROM numbers(50);
SELECT * FROM tab ORDER BY toUInt128(uuid);

結果:

┌─uuid─────────────────────────────────┐
018b81cd-aca1-4e9c-9e56-a84a074dc1a8 │
02380033-c96a-438e-913f-a2c67e341def │
057cf435-7044-456a-893b-9183a4475cea │
0a3c1d4c-f57d-44cc-8567-60cb0c46f76e │
0c15bf1c-8633-4414-a084-7017eead9e41 │
[...]
│ f808cf05-ea57-4e81-8add-29a195bde63d │
│ f859fb5d-764b-4a33-81e6-9e4239dae083 │
│ fb1b7e37-ab7b-421a-910b-80e60e2bf9eb │
│ fc3174ff-517b-49b5-bfe2-9b369a5c506d │
│ fece9bf6-3832-449a-b058-cd1d70a02c8b │
└──────────────────────────────────────┘

UUIDの生成

ClickHouseは、ランダムなUUIDバージョン4の値を生成するためのgenerateUUIDv4関数を提供しています。

使用例

例 1

この例では、UUIDカラムを持つテーブルの作成とテーブルへの値の挿入を示します。

CREATE TABLE t_uuid (x UUID, y String) ENGINE=TinyLog

INSERT INTO t_uuid SELECT generateUUIDv4(), 'Example 1'

SELECT * FROM t_uuid

結果:

┌────────────────────────────────────x─┬─y─────────┐
│ 417ddc5d-e556-4d27-95dd-a34d84e46a50 │ Example 1 │
└──────────────────────────────────────┴───────────┘

例 2

この例では、レコードを挿入する際にUUIDカラムの値が指定されていないため、デフォルトのUUID値が挿入されます。

INSERT INTO t_uuid (y) VALUES ('Example 2')

SELECT * FROM t_uuid
┌────────────────────────────────────x─┬─y─────────┐
│ 417ddc5d-e556-4d27-95dd-a34d84e46a50 │ Example 1 │
│ 00000000-0000-0000-0000-000000000000 │ Example 2 │
└──────────────────────────────────────┴───────────┘

制限事項

UUIDデータ型は、minmax、およびcountなど、Stringデータ型がサポートする関数のみをサポートします。

UUIDデータ型は、absなどの算術演算や、sumavgなどの集計関数をサポートしていません。