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

> Crea una tabla a partir de una `URL` con el `format` y la `estructura` especificados

# Función de tabla url

export const CloudNotSupportedBadge = () => {
  return <div className="cloudNotSupportedBadge">
            <div className="cloudNotSupportedIcon">
            <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
                <path strokeWidth="1.5" d="M6.33366 12.6666L12.3739 12.6667C13.6593 12.6667 14.7073 11.6187 14.7073 10.3334C14.7073 9.04804 13.6593 8.00003 12.3739 8.00003C12.3739 8.00003 12.3337 7.66659 12.0003 7.33325M10.667 5.33322C8.00033 2.33325 4.45395 4.78537 4.14195 6.68203C2.55728 6.7627 1.29395 8.06203 1.29395 9.6667C1.29395 11.3234 2.66699 12.6666 4.00033 12.6666" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
                <path strokeWidth="1.5" d="M2.66699 14L12.0003 4.66663" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
            </svg>

        </div>
            Not supported in ClickHouse Cloud
        </div>;
};

export const ExperimentalBadge = () => {
  return <div className="experimentalBadge">
            <div className="experimentalIcon">
            <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
                <path strokeWidth="1.25" d="M5.5 2H10.5" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
                <path strokeWidth="1.25" d="M9.50015 2V6.19625L13.4283 12.7425C13.4738 12.8183 13.4985 12.9049 13.4996 12.9934C13.5008 13.0818 13.4785 13.169 13.435 13.246C13.3914 13.323 13.3283 13.3871 13.2519 13.4317C13.1755 13.4764 13.0886 13.4999 13.0002 13.5H3.00015C2.91164 13.5 2.8247 13.4766 2.74822 13.432C2.67174 13.3874 2.60847 13.3233 2.56487 13.2463C2.52126 13.1693 2.49889 13.082 2.50004 12.9935C2.50119 12.905 2.52582 12.8184 2.5714 12.7425L6.50015 6.19625V2" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
                <path strokeWidth="1.25" d="M4.47656 9.56754C5.30344 9.41254 6.47656 9.47942 7.99969 10.25C10.0153 11.2707 11.4216 11.0569 12.2184 10.7282" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" />
            </svg>
        </div>
            Experimental feature. <u><a href="/docs/beta-and-experimental-features#experimental-features">Learn more.</a></u>
        </div>;
};

La función `url` crea una tabla a partir de una `URL` con el `format` y la `estructura` especificados.

La función `url` puede utilizarse en consultas `SELECT` e `INSERT` sobre datos de tablas [URL](/es/reference/engines/table-engines/special/url).

<div id="syntax">
  ## Sintaxis
</div>

```sql theme={null}
url(URL [,format] [,structure] [,headers])
```

<div id="parameters">
  ## Parámetros
</div>

| Parámetro   | Descripción                                                                                                                                                                                                     |
| ----------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `URL`       | Dirección del servidor HTTP o HTTPS entre comillas simples, que puede aceptar peticiones `GET` o `POST` (para consultas `SELECT` o `INSERT`, respectivamente). Tipo: [String](/es/reference/data-types/string). |
| `format`    | [Format](/es/reference/formats) de los datos. Tipo: [String](/es/reference/data-types/string).                                                                                                                  |
| `structure` | Structure de la tabla en el formato `'UserID UInt64, Name String'`. Determina los nombres de las columnas y sus tipos. Tipo: [String](/es/reference/data-types/string).                                         |
| `headers`   | Encabezados en el formato `'headers('key1'='value1', 'key2'='value2')'`. Puede configurar encabezados para la llamada HTTP.                                                                                     |

<div id="returned_value">
  ## Valor devuelto
</div>

Una tabla con el formato y la estructura especificados, y con datos de la `URL` indicada.

<div id="examples">
  ## Ejemplos
</div>

Obtener las primeras 3 líneas de una tabla que contiene columnas de tipo `String` y [UInt32](/es/reference/data-types/int-uint) desde un servidor HTTP que responde en formato [CSV](/es/reference/formats/CSV/CSV).

```sql theme={null}
SELECT * FROM url('http://127.0.0.1:12345/', CSV, 'column1 String, column2 UInt32', headers('Accept'='text/csv; charset=utf-8')) LIMIT 3;
```

Insertar datos de una `URL` en una tabla:

```sql theme={null}
CREATE TABLE test_table (column1 String, column2 UInt32) ENGINE=Memory;
INSERT INTO FUNCTION url('http://127.0.0.1:8123/?query=INSERT+INTO+test_table+FORMAT+CSV', 'CSV', 'column1 String, column2 UInt32') VALUES ('http interface', 42);
SELECT * FROM test_table;
```

<div id="globs-in-url">
  ## Globs en URL
</div>

Los patrones entre `{ }` se utilizan para generar un conjunto de segmentos o para especificar direcciones de failover. Para ver los tipos de patrones admitidos y ejemplos, consulte la descripción de la función [remote](/es/reference/functions/table-functions/remote#globs-in-addresses).
El carácter `|` dentro de los patrones se utiliza para especificar direcciones de failover. Se recorren en el mismo orden en que aparecen en el patrón. El número de direcciones generadas está limitado por la configuración [glob\_expansion\_max\_elements](/es/reference/settings/session-settings#glob_expansion_max_elements).

<div id="virtual-columns">
  ## Columnas virtuales
</div>

* `_path` — Ruta de la `URL`. Tipo: `LowCardinality(String)`.
* `_file` — Nombre del recurso de la `URL`. Tipo: `LowCardinality(String)`.
* `_size` — Tamaño del recurso en bytes. Tipo: `Nullable(UInt64)`. Si se desconoce el tamaño, el valor es `NULL`.
* `_time` — Fecha y hora de la última modificación del archivo. Tipo: `Nullable(DateTime)`. Si se desconoce la hora, el valor es `NULL`.
* `_headers` - Encabezados de la respuesta HTTP. Tipo: `Map(LowCardinality(String), LowCardinality(String))`.

<div id="hive-style-partitioning">
  ## configuración use\_hive\_partitioning
</div>

Cuando la configuración `use_hive_partitioning` se establece en 1, ClickHouse detecta el particionamiento al estilo Hive en la ruta (`/name=value/`) y permite usar las columnas de partición como columnas virtuales en la consulta. Estas columnas virtuales tendrán los mismos nombres que en la ruta particionada.

**Ejemplo**

Uso de una columna virtual creada con particionamiento al estilo Hive

```sql theme={null}
SELECT * FROM url('http://data/path/date=*/country=*/code=*/*.parquet') WHERE date > '2020-01-01' AND country = 'Netherlands' AND code = 42;
```

<div id="resolving-relative-urls">
  ## Resolución de URL relativas
</div>

La configuración [url\_base](/es/reference/settings/session-settings#url_base) permite pasar una URL relativa a la función `url`. Cuando se establece `url_base` y el argumento de la función es una referencia relativa, esta se resuelve con respecto a la URL base según [RFC 3986](https://datatracker.ietf.org/doc/html/rfc3986).

Las reglas de resolución son:

* **Relativa a la ruta** (p. ej., `data.csv`): se combina con la ruta de la URL base; todo lo que aparece después de la última `/` de la ruta base se reemplaza. La barra diagonal final importa: `https://example.com/dir/` + `data.csv` da `https://example.com/dir/data.csv`, pero `https://example.com/dir` + `data.csv` da `https://example.com/data.csv`. Los segmentos de punto (`./` y `../`) se normalizan.
* **Relativa al host** (p. ej., `/test/data.csv`): se resuelve usando el esquema y el host de la URL base.
* **Relativa al esquema** (p. ej., `//other.com/test/data.csv`): se resuelve usando el esquema de la URL base.
* **Solo cadena de consulta** (p. ej., `?x=1`): se añade a la ruta base completa y reemplaza cualquier cadena de consulta o fragmento existente.
* **Solo fragmento** (p. ej., `#frag`): se añade a la URL base, conserva la cadena de consulta y reemplaza cualquier fragmento existente.
* **Vacía**: devuelve la URL base sin fragmento.
* **URL absoluta**: se pasa sin cambios; `url_base` se ignora.

**Ejemplo**

```sql theme={null}
SET url_base = 'https://raw.githubusercontent.com/ClickHouse/ClickHouse/master/';
SELECT * FROM url('tests/queries/0_stateless/data_csv/data.csv', CSV) LIMIT 3;
```

<div id="storage-settings">
  ## Configuración de almacenamiento
</div>

* [engine\_url\_skip\_empty\_files](/es/reference/settings/session-settings#engine_url_skip_empty_files) - permite omitir archivos vacíos durante la lectura. Desactivado de forma predeterminada.
* [enable\_url\_encoding](/es/reference/settings/session-settings#enable_url_encoding) - permite activar/desactivar la codificación y decodificación de la ruta en el URI. Activado de forma predeterminada.
* [url\_base](/es/reference/settings/session-settings#url_base) - URL base para resolver las URL relativas que se pasan a la función `url`.

<div id="permissions">
  ## Permisos
</div>

La función `url` requiere el permiso `CREATE TEMPORARY TABLE`. Por lo tanto, no funcionará para los usuarios con la opción [readonly](/es/concepts/features/configuration/settings/permissions-for-queries#readonly) = 1. Se requiere como mínimo readonly = 2.

<div id="related">
  ## Relacionado
</div>

* [Columnas virtuales](/es/reference/engines/table-engines#table_engines-virtual_columns)
