mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-01 20:12:02 +00:00
cd14f9ebcb
* split up select.md * array-join.md basic refactoring * distinct.md basic refactoring * format.md basic refactoring * from.md basic refactoring * group-by.md basic refactoring * having.md basic refactoring * additional index.md refactoring * into-outfile.md basic refactoring * join.md basic refactoring * limit.md basic refactoring * limit-by.md basic refactoring * order-by.md basic refactoring * prewhere.md basic refactoring * adjust operators/index.md links * adjust sample.md links * adjust more links * adjust operatots links * fix some links * adjust aggregate function article titles * basic refactor of remaining select clauses * absolute paths in make_links.sh * run make_links.sh * remove old select.md locations * translate docs/es * translate docs/fr * translate docs/fa * remove old operators.md location * change operators.md links * adjust links in docs/es * adjust links in docs/es * minor texts adjustments * wip * update machine translations to use new links * fix changelog * es build fixes * get rid of some select.md links * temporary adjust ru links * temporary adjust more ru links * improve curly brace handling * adjust ru as well * fa build fix * ru link fixes * zh link fixes * temporary disable part of anchor checks
249 lines
9.6 KiB
Markdown
249 lines
9.6 KiB
Markdown
---
|
||
machine_translated: true
|
||
machine_translated_rev: 72537a2d527c63c07aa5d2361a8829f3895cf2bd
|
||
toc_priority: 55
|
||
toc_title: Trabajar con direcciones IP
|
||
---
|
||
|
||
# Funciones para trabajar con direcciones IP {#functions-for-working-with-ip-addresses}
|
||
|
||
## Número de código: IPv4NumToString (num) {#ipv4numtostringnum}
|
||
|
||
Toma un número UInt32. Lo interpreta como una dirección IPv4 en big endian. Devuelve una cadena que contiene la dirección IPv4 correspondiente en el formato A.B.C.d (números separados por puntos en forma decimal).
|
||
|
||
## Nombre de la red inalámbrica (SSID):) {#ipv4stringtonums}
|
||
|
||
La función inversa de IPv4NumToString. Si la dirección IPv4 tiene un formato no válido, devuelve 0.
|
||
|
||
## Cómo hacer esto?) {#ipv4numtostringclasscnum}
|
||
|
||
Similar a IPv4NumToString, pero usando xxx en lugar del último octeto.
|
||
|
||
Ejemplo:
|
||
|
||
``` sql
|
||
SELECT
|
||
IPv4NumToStringClassC(ClientIP) AS k,
|
||
count() AS c
|
||
FROM test.hits
|
||
GROUP BY k
|
||
ORDER BY c DESC
|
||
LIMIT 10
|
||
```
|
||
|
||
``` text
|
||
┌─k──────────────┬─────c─┐
|
||
│ 83.149.9.xxx │ 26238 │
|
||
│ 217.118.81.xxx │ 26074 │
|
||
│ 213.87.129.xxx │ 25481 │
|
||
│ 83.149.8.xxx │ 24984 │
|
||
│ 217.118.83.xxx │ 22797 │
|
||
│ 78.25.120.xxx │ 22354 │
|
||
│ 213.87.131.xxx │ 21285 │
|
||
│ 78.25.121.xxx │ 20887 │
|
||
│ 188.162.65.xxx │ 19694 │
|
||
│ 83.149.48.xxx │ 17406 │
|
||
└────────────────┴───────┘
|
||
```
|
||
|
||
Desde el uso ‘xxx’ es altamente inusual, esto puede cambiarse en el futuro. Le recomendamos que no confíe en el formato exacto de este fragmento.
|
||
|
||
### ¿Cómo puedo hacerlo?) {#ipv6numtostringx}
|
||
|
||
Acepta un valor FixedString(16) que contiene la dirección IPv6 en formato binario. Devuelve una cadena que contiene esta dirección en formato de texto.
|
||
Las direcciones IPv4 asignadas a IPv6 se emiten en el formato ::ffff:111.222.33.44. Ejemplos:
|
||
|
||
``` sql
|
||
SELECT IPv6NumToString(toFixedString(unhex('2A0206B8000000000000000000000011'), 16)) AS addr
|
||
```
|
||
|
||
``` text
|
||
┌─addr─────────┐
|
||
│ 2a02:6b8::11 │
|
||
└──────────────┘
|
||
```
|
||
|
||
``` sql
|
||
SELECT
|
||
IPv6NumToString(ClientIP6 AS k),
|
||
count() AS c
|
||
FROM hits_all
|
||
WHERE EventDate = today() AND substring(ClientIP6, 1, 12) != unhex('00000000000000000000FFFF')
|
||
GROUP BY k
|
||
ORDER BY c DESC
|
||
LIMIT 10
|
||
```
|
||
|
||
``` text
|
||
┌─IPv6NumToString(ClientIP6)──────────────┬─────c─┐
|
||
│ 2a02:2168:aaa:bbbb::2 │ 24695 │
|
||
│ 2a02:2698:abcd:abcd:abcd:abcd:8888:5555 │ 22408 │
|
||
│ 2a02:6b8:0:fff::ff │ 16389 │
|
||
│ 2a01:4f8:111:6666::2 │ 16016 │
|
||
│ 2a02:2168:888:222::1 │ 15896 │
|
||
│ 2a01:7e00::ffff:ffff:ffff:222 │ 14774 │
|
||
│ 2a02:8109:eee:ee:eeee:eeee:eeee:eeee │ 14443 │
|
||
│ 2a02:810b:8888:888:8888:8888:8888:8888 │ 14345 │
|
||
│ 2a02:6b8:0:444:4444:4444:4444:4444 │ 14279 │
|
||
│ 2a01:7e00::ffff:ffff:ffff:ffff │ 13880 │
|
||
└─────────────────────────────────────────┴───────┘
|
||
```
|
||
|
||
``` sql
|
||
SELECT
|
||
IPv6NumToString(ClientIP6 AS k),
|
||
count() AS c
|
||
FROM hits_all
|
||
WHERE EventDate = today()
|
||
GROUP BY k
|
||
ORDER BY c DESC
|
||
LIMIT 10
|
||
```
|
||
|
||
``` text
|
||
┌─IPv6NumToString(ClientIP6)─┬──────c─┐
|
||
│ ::ffff:94.26.111.111 │ 747440 │
|
||
│ ::ffff:37.143.222.4 │ 529483 │
|
||
│ ::ffff:5.166.111.99 │ 317707 │
|
||
│ ::ffff:46.38.11.77 │ 263086 │
|
||
│ ::ffff:79.105.111.111 │ 186611 │
|
||
│ ::ffff:93.92.111.88 │ 176773 │
|
||
│ ::ffff:84.53.111.33 │ 158709 │
|
||
│ ::ffff:217.118.11.22 │ 154004 │
|
||
│ ::ffff:217.118.11.33 │ 148449 │
|
||
│ ::ffff:217.118.11.44 │ 148243 │
|
||
└────────────────────────────┴────────┘
|
||
```
|
||
|
||
## Nombre de la red inalámbrica (SSID):) {#ipv6stringtonums}
|
||
|
||
La función inversa de IPv6NumToString. Si la dirección IPv6 tiene un formato no válido, devuelve una cadena de bytes nulos.
|
||
HEX puede ser mayúscula o minúscula.
|
||
|
||
## IPv4ToIPv6 (x) {#ipv4toipv6x}
|
||
|
||
Toma un `UInt32` numero. Lo interpreta como una dirección IPv4 en [gran endian](https://en.wikipedia.org/wiki/Endianness). Devuelve un `FixedString(16)` valor que contiene la dirección IPv6 en formato binario. Ejemplos:
|
||
|
||
``` sql
|
||
SELECT IPv6NumToString(IPv4ToIPv6(IPv4StringToNum('192.168.0.1'))) AS addr
|
||
```
|
||
|
||
``` text
|
||
┌─addr───────────────┐
|
||
│ ::ffff:192.168.0.1 │
|
||
└────────────────────┘
|
||
```
|
||
|
||
## Para obtener más información, consulta nuestra Política de privacidad y nuestras Condiciones de uso) {#cutipv6x-bytestocutforipv6-bytestocutforipv4}
|
||
|
||
Acepta un valor FixedString(16) que contiene la dirección IPv6 en formato binario. Devuelve una cadena que contiene la dirección del número especificado de bytes eliminados en formato de texto. Por ejemplo:
|
||
|
||
``` sql
|
||
WITH
|
||
IPv6StringToNum('2001:0DB8:AC10:FE01:FEED:BABE:CAFE:F00D') AS ipv6,
|
||
IPv4ToIPv6(IPv4StringToNum('192.168.0.1')) AS ipv4
|
||
SELECT
|
||
cutIPv6(ipv6, 2, 0),
|
||
cutIPv6(ipv4, 0, 2)
|
||
```
|
||
|
||
``` text
|
||
┌─cutIPv6(ipv6, 2, 0)─────────────────┬─cutIPv6(ipv4, 0, 2)─┐
|
||
│ 2001:db8:ac10:fe01:feed:babe:cafe:0 │ ::ffff:192.168.0.0 │
|
||
└─────────────────────────────────────┴─────────────────────┘
|
||
```
|
||
|
||
## IPv4CIDRToRange (ipv4, Cidr), {#ipv4cidrtorangeipv4-cidr}
|
||
|
||
Acepta un valor IPv4 y UInt8 que contiene el valor [CIDR](https://en.wikipedia.org/wiki/Classless_Inter-Domain_Routing). Devuelve una tupla con dos IPv4 que contienen el rango inferior y el rango superior de la subred.
|
||
|
||
``` sql
|
||
SELECT IPv4CIDRToRange(toIPv4('192.168.5.2'), 16)
|
||
```
|
||
|
||
``` text
|
||
┌─IPv4CIDRToRange(toIPv4('192.168.5.2'), 16)─┐
|
||
│ ('192.168.0.0','192.168.255.255') │
|
||
└────────────────────────────────────────────┘
|
||
```
|
||
|
||
## IPv6CIDRToRange(ipv6, Cidr), {#ipv6cidrtorangeipv6-cidr}
|
||
|
||
Acepta un valor IPv6 y UInt8 que contiene el CIDR. Devuelve una tupla con dos IPv6 que contienen el rango inferior y el rango superior de la subred.
|
||
|
||
``` sql
|
||
SELECT IPv6CIDRToRange(toIPv6('2001:0db8:0000:85a3:0000:0000:ac1f:8001'), 32);
|
||
```
|
||
|
||
``` text
|
||
┌─IPv6CIDRToRange(toIPv6('2001:0db8:0000:85a3:0000:0000:ac1f:8001'), 32)─┐
|
||
│ ('2001:db8::','2001:db8:ffff:ffff:ffff:ffff:ffff:ffff') │
|
||
└────────────────────────────────────────────────────────────────────────┘
|
||
```
|
||
|
||
## Acerca de nosotros) {#toipv4string}
|
||
|
||
Un alias para `IPv4StringToNum()` que toma una forma de cadena de dirección IPv4 y devuelve el valor de [IPv4](../../sql-reference/data-types/domains/ipv4.md) tipo, que es binario igual al valor devuelto por `IPv4StringToNum()`.
|
||
|
||
``` sql
|
||
WITH
|
||
'171.225.130.45' as IPv4_string
|
||
SELECT
|
||
toTypeName(IPv4StringToNum(IPv4_string)),
|
||
toTypeName(toIPv4(IPv4_string))
|
||
```
|
||
|
||
``` text
|
||
┌─toTypeName(IPv4StringToNum(IPv4_string))─┬─toTypeName(toIPv4(IPv4_string))─┐
|
||
│ UInt32 │ IPv4 │
|
||
└──────────────────────────────────────────┴─────────────────────────────────┘
|
||
```
|
||
|
||
``` sql
|
||
WITH
|
||
'171.225.130.45' as IPv4_string
|
||
SELECT
|
||
hex(IPv4StringToNum(IPv4_string)),
|
||
hex(toIPv4(IPv4_string))
|
||
```
|
||
|
||
``` text
|
||
┌─hex(IPv4StringToNum(IPv4_string))─┬─hex(toIPv4(IPv4_string))─┐
|
||
│ ABE1822D │ ABE1822D │
|
||
└───────────────────────────────────┴──────────────────────────┘
|
||
```
|
||
|
||
## Acerca de nosotros) {#toipv6string}
|
||
|
||
Un alias para `IPv6StringToNum()` que toma una forma de cadena de dirección IPv6 y devuelve el valor de [IPv6](../../sql-reference/data-types/domains/ipv6.md) tipo, que es binario igual al valor devuelto por `IPv6StringToNum()`.
|
||
|
||
``` sql
|
||
WITH
|
||
'2001:438:ffff::407d:1bc1' as IPv6_string
|
||
SELECT
|
||
toTypeName(IPv6StringToNum(IPv6_string)),
|
||
toTypeName(toIPv6(IPv6_string))
|
||
```
|
||
|
||
``` text
|
||
┌─toTypeName(IPv6StringToNum(IPv6_string))─┬─toTypeName(toIPv6(IPv6_string))─┐
|
||
│ FixedString(16) │ IPv6 │
|
||
└──────────────────────────────────────────┴─────────────────────────────────┘
|
||
```
|
||
|
||
``` sql
|
||
WITH
|
||
'2001:438:ffff::407d:1bc1' as IPv6_string
|
||
SELECT
|
||
hex(IPv6StringToNum(IPv6_string)),
|
||
hex(toIPv6(IPv6_string))
|
||
```
|
||
|
||
``` text
|
||
┌─hex(IPv6StringToNum(IPv6_string))─┬─hex(toIPv6(IPv6_string))─────────┐
|
||
│ 20010438FFFF000000000000407D1BC1 │ 20010438FFFF000000000000407D1BC1 │
|
||
└───────────────────────────────────┴──────────────────────────────────┘
|
||
```
|
||
|
||
[Artículo Original](https://clickhouse.tech/docs/en/query_language/functions/ip_address_functions/) <!--hide-->
|