O ClickHouse oferece suporte a dicionários hierárquicos com uma chave numérica.
Veja a seguinte estrutura hierárquica:
0 (Pai comum)
│
├── 1 (Russia)
│ │
│ └── 2 (Moscou)
│ │
│ └── 3 (Centro)
│
└── 4 (Grã-Bretanha)
│
└── 5 (Londres)
Essa hierarquia pode ser expressa na seguinte tabela do dicionário.
| region_id | parent_region | region_name |
|---|
| 1 | 0 | Russia |
| 2 | 1 | Moscow |
| 3 | 2 | Center |
| 4 | 0 | Great Britain |
| 5 | 4 | London |
Esta tabela contém uma coluna parent_region que armazena a chave do pai mais próximo do elemento.
O ClickHouse oferece suporte à propriedade hierárquica para atributos de dicionários externos. Essa propriedade permite configurar o dicionário hierárquico de forma semelhante à descrita acima.
A função dictGetHierarchy permite obter a cadeia de pais de um elemento.
No nosso exemplo, a estrutura do dicionário pode ser a seguinte:
DDL
Arquivo de configuração
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);
<dictionary>
<structure>
<id>
<name>region_id</name>
</id>
<attribute>
<name>parent_region</name>
<type>UInt64</type>
<null_value>0</null_value>
<hierarchical>true</hierarchical>
</attribute>
<attribute>
<name>region_name</name>
<type>String</type>
<null_value></null_value>
</attribute>
</structure>
</dictionary>
Última modificação em 10 de junho de 2026