ClickHouse/docs/tr/sql-reference/dictionaries/external-dictionaries/external-dicts-dict-hierarchical.md

71 lines
2.1 KiB
Markdown
Raw Normal View History

2020-04-15 13:56:49 +00:00
---
machine_translated: true
machine_translated_rev: 72537a2d527c63c07aa5d2361a8829f3895cf2bd
2020-04-15 13:56:49 +00:00
toc_priority: 45
toc_title: "Hiyerar\u015Fik s\xF6zl\xFCkler"
---
# Hiyerarşik Sözlükler {#hierarchical-dictionaries}
ClickHouse bir hiyerarşik sözlükler destekler [sayısal tuş](external-dicts-dict-structure.md#ext_dict-numeric-key).
2020-04-15 13:56:49 +00:00
Aşağıdaki hiyerarşik yapıya bakın:
``` text
0 (Common parent)
├── 1 (Russia)
│ │
│ └── 2 (Moscow)
│ │
│ └── 3 (Center)
└── 4 (Great Britain)
└── 5 (London)
```
Bu hiyerarşi aşağıdaki sözlük tablosu olarak ifade edilebilir.
2020-10-13 17:23:29 +00:00
| region_id | parent_region | region_name |
2020-04-15 13:56:49 +00:00
|------------|----------------|--------------|
| 1 | 0 | Rusya |
| 2 | 1 | Moskova |
| 3 | 2 | Merkezli |
| 4 | 0 | İngiltere |
| 5 | 4 | Londra |
Bu tablo bir sütun içerir `parent_region` bu öğe için en yakın ebeveynin anahtarını içerir.
ClickHouse destekler [hiyerarşik](external-dicts-dict-structure.md#hierarchical-dict-attr) için mülkiyet [dış sözlük](index.md) öznitelik. Bu özellik, yukarıda açıklanana benzer hiyerarşik sözlüğü yapılandırmanıza izin verir.
2020-04-15 13:56:49 +00:00
Bu [dictGetHierarchy](../../../sql-reference/functions/ext-dict-functions.md#dictgethierarchy) fonksiyonu bir elemanın üst zincir almak için izin verir.
2020-04-15 13:56:49 +00:00
Örneğimiz için, sözlüğün yapısı aşağıdaki gibi olabilir:
``` 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>
```
[Orijinal makale](https://clickhouse.tech/docs/en/query_language/dicts/external_dicts_dict_hierarchical/) <!--hide-->