--- toc_priority: 45 toc_title: "\u0418\u0435\u0440\u0430\u0440\u0445\u0438\u0447\u0435\u0441\u043a\u0438\u0435\u0020\u0441\u043b\u043e\u0432\u0430\u0440\u0438" --- # Иерархические словари {#ierarkhicheskie-slovari} ClickHouse поддерживает иерархические словари с [числовыми ключом](external-dicts-dict-structure.md#ext_dict-numeric-key). Рассмотрим следующую структуру: ``` text 0 (Common parent) │ ├── 1 (Russia) │ │ │ └── 2 (Moscow) │ │ │ └── 3 (Center) │ └── 4 (Great Britain) │ └── 5 (London) ``` Эту иерархию можно выразить в виде следующей таблицы-словаря. | region_id | parent_region | region_name | |------------|----------------|---------------| | 1 | 0 | Russia | | 2 | 1 | Moscow | | 3 | 2 | Center | | 4 | 0 | Great Britain | | 5 | 4 | London | Таблица содержит столбец `parent_region`, содержащий ключ ближайшего предка для текущего элемента. ClickHouse поддерживает свойство [hierarchical](external-dicts-dict-structure.md#hierarchical-dict-attr) для атрибутов [внешнего словаря](index.md). Это свойство позволяет конфигурировать словари, подобные описанному выше. С помощью функции [dictGetHierarchy](../../../sql-reference/functions/ext-dict-functions.md#dictgethierarchy) можно получить цепочку предков элемента. Структура словаря для нашего примера может выглядеть следующим образом: ``` xml region_id parent_region UInt64 0 true region_name String ``` [Оригинальная статья](https://clickhouse.tech/docs/ru/query_language/dicts/external_dicts_dict_hierarchical/)