跳转到主要内容

层级字典

ClickHouse 支持使用数值键的层级字典。 请看下面的分层结构:
0 (Common parent)

├── 1 (Russia)
│   │
│   └── 2 (Moscow)
│       │
│       └── 3 (Center)

└── 4 (Great Britain)

    └── 5 (London)
这种层级关系可以用下表所示的字典表来表示。
region_idparent_regionregion_name
10Russia
21Moscow
32Center
40Great Britain
54London
该表包含一个 parent_region 列,用于存储该元素最近父级的键。 ClickHouse 支持外部字典属性的层级特性。借助该特性,你可以按上述方式配置层级字典。 dictGetHierarchy 函数可用于获取某个元素的父级链。 在本例中,字典结构可以如下所示:
CREATE DICTIONARY regions_dict
(
    region_id UInt64,
    parent_region UInt64 DEFAULT 0 HIERARCHICAL,
    region_name String DEFAULT ''
)
PRIMARY KEY region_id
SOURCE(...)
LAYOUT(HASHED())
LIFETIME(3600);

最后修改于 2026年6月10日