> ## Documentation Index
> Fetch the complete documentation index at: https://private-7c7dfe99-fix-nav-issues.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# layout del diccionario ip_trie

> Almacena un diccionario como un trie para búsquedas rápidas de prefijos de direcciones IP.

El diccionario `ip_trie` está diseñado para búsquedas de direcciones IP por prefijo de red.
Almacena rangos de IP en notación CIDR y permite determinar rápidamente en qué prefijo (p. ej., subred o rango de ASN) se encuentra una IP dada, lo que lo hace ideal para búsquedas basadas en IP, como la geolocalización o la clasificación de redes.

<Frame>
  <iframe src="https://www.youtube.com/embed/4dxMAqltygk?si=rrQrneBReK6lLfza" title="Búsqueda basada en IP con el diccionario ip_trie" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerpolicy="strict-origin-when-cross-origin" allowfullscreen />
</Frame>

**Ejemplo**

Supongamos que tenemos una tabla en ClickHouse que contiene nuestros prefijos de IP y sus asignaciones:

```sql theme={null}
CREATE TABLE my_ip_addresses (
    prefix String,
    asn UInt32,
    cca2 String
)
ENGINE = MergeTree
PRIMARY KEY prefix;
```

```sql theme={null}
INSERT INTO my_ip_addresses VALUES
    ('202.79.32.0/20', 17501, 'NP'),
    ('2620:0:870::/48', 3856, 'US'),
    ('2a02:6b8:1::/48', 13238, 'RU'),
    ('2001:db8::/32', 65536, 'ZZ')
;
```

Definamos un diccionario `ip_trie` para esta tabla. El layout `ip_trie` requiere una clave compuesta:

<Tabs>
  <Tab title="DDL">
    ```sql theme={null}
    CREATE DICTIONARY my_ip_trie_dictionary (
        prefix String,
        asn UInt32,
        cca2 String DEFAULT '??'
    )
    PRIMARY KEY prefix
    SOURCE(CLICKHOUSE(TABLE 'my_ip_addresses'))
    LAYOUT(IP_TRIE)
    LIFETIME(3600);
    ```
  </Tab>

  <Tab title="Archivo de configuración">
    ```xml theme={null}
    <structure>
        <key>
            <attribute>
                <name>prefix</name>
                <type>String</type>
            </attribute>
        </key>
        <attribute>
                <name>asn</name>
                <type>UInt32</type>
                <null_value />
        </attribute>
        <attribute>
                <name>cca2</name>
                <type>String</type>
                <null_value>??</null_value>
        </attribute>
        ...
    </structure>
    <layout>
        <ip_trie>
            <!-- El atributo de clave `prefix` se puede recuperar con dictGetString. -->
            <!-- Esta opción aumenta el uso de memoria. -->
            <access_to_key_from_attributes>true</access_to_key_from_attributes>
        </ip_trie>
    </layout>
    ```
  </Tab>
</Tabs>

<br />

La clave debe tener un único atributo de tipo `String` que contenga un prefijo IP válido. Otros tipos todavía no son compatibles.

La sintaxis es:

```sql theme={null}
dictGetT('dict_name', 'attr_name', ip)
```

La función recibe `UInt32` para IPv4 o `FixedString(16)` para IPv6. Por ejemplo:

```sql theme={null}
SELECT dictGet('my_ip_trie_dictionary', 'cca2', toIPv4('202.79.32.10')) AS result;

┌─result─┐
│ NP     │
└────────┘

SELECT dictGet('my_ip_trie_dictionary', 'asn', IPv6StringToNum('2001:db8::1')) AS result;

┌─result─┐
│  65536 │
└────────┘

SELECT dictGet('my_ip_trie_dictionary', ('asn', 'cca2'), IPv6StringToNum('2001:db8::1')) AS result;

┌─result───────┐
│ (65536,'ZZ') │
└──────────────┘
```

Otros tipos todavía no son compatibles. La función devuelve el atributo del prefijo correspondiente a esta dirección IP. Si hay prefijos superpuestos, se devuelve el más específico.

Los datos deben caber por completo en la RAM.
