mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-07 16:14:52 +00:00
9ec78855cd
* DOCSUP-2806: Add meta intro. * DOCSUP-2806: Update meta intro. * DOCSUP-2806: Fix meta. * DOCSUP-2806: Add quotes for meta headers. * DOCSUP-2806: Remove quotes from meta headers. * DOCSUP-2806: Add meta headers. * DOCSUP-2806: Fix quotes in meta headers. * DOCSUP-2806: Update meta headers. * DOCSUP-2806: Fix link to nowhere in EN. * DOCSUP-2806: Fix link (settings to tune) * DOCSUP-2806: Fix links. * DOCSUP-2806:Fix links EN * DOCSUP-2806: Fix build errors. * DOCSUP-2806: Fix meta intro. * DOCSUP-2806: Fix toc_priority in examples datasets TOC. * DOCSUP-2806: Fix items order in toc. * DOCSUP-2806: Fix order in toc. * DOCSUP-2806: Fix toc order. * DOCSUP-2806: Fix order in toc. * DOCSUP-2806: Fix toc index in create * DOCSUP-2806: Fix toc order in create. Co-authored-by: romanzhukov <romanzhukov@yandex-team.ru> Co-authored-by: alexey-milovidov <milovidov@yandex-team.ru>
69 lines
2.5 KiB
Markdown
69 lines
2.5 KiB
Markdown
---
|
||
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
|
||
<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>
|
||
```
|
||
|
||
[Оригинальная статья](https://clickhouse.tech/docs/ru/query_language/dicts/external_dicts_dict_hierarchical/) <!--hide-->
|