* replace exit with assert in test_single_page * improve save_raw_single_page docs option * More grammar fixes * "Built from" link in new tab * fix mistype * Example of include in docs * add anchor to meeting form * Draft of translation helper * WIP on translation helper * Replace some fa docs content with machine translation * add normalize-en-markdown.sh * normalize some en markdown * normalize some en markdown * admonition support * normalize * normalize * normalize * support wide tables * normalize * normalize * normalize * normalize * normalize * normalize * normalize * normalize * normalize * normalize * normalize * normalize * normalize * lightly edited machine translation of introdpection.md * lightly edited machhine translation of lazy.md * WIP on translation utils * Normalize ru docs * Normalize other languages * some fixes * WIP on normalize/translate tools * add requirements.txt * [experimental] add es docs language as machine translated draft * remove duplicate script * Back to wider tab-stop (narrow renders not so well)
3.9 KiB
MySQL
El motor MySQL le permite realizar SELECT
consultas sobre datos almacenados en un servidor MySQL remoto.
Creación de una tabla
CREATE TABLE [IF NOT EXISTS] [db.]table_name [ON CLUSTER cluster]
(
name1 [type1] [DEFAULT|MATERIALIZED|ALIAS expr1] [TTL expr1],
name2 [type2] [DEFAULT|MATERIALIZED|ALIAS expr2] [TTL expr2],
...
) ENGINE = MySQL('host:port', 'database', 'table', 'user', 'password'[, replace_query, 'on_duplicate_clause']);
Vea una descripción detallada del CREAR TABLA consulta.
La estructura de la tabla puede diferir de la estructura de la tabla MySQL original:
- Los nombres de columna deben ser los mismos que en la tabla MySQL original, pero puede usar solo algunas de estas columnas y en cualquier orden.
- Los tipos de columna pueden diferir de los de la tabla MySQL original. ClickHouse intenta elenco valores a los tipos de datos ClickHouse.
Parámetros del motor
-
host:port
— Dirección del servidor MySQL. -
database
— Nombre de base de datos remota. -
table
— Nombre de la tabla remota. -
user
— Usuario de MySQL. -
password
— Contraseña de usuario. -
replace_query
— Bandera que convierteINSERT INTO
consultas aREPLACE INTO
. Sireplace_query=1
, la consulta se sustituye. -
on_duplicate_clause
— ElON DUPLICATE KEY on_duplicate_clause
expresión que se añade a laINSERT
consulta.Ejemplo:
INSERT INTO t (c1,c2) VALUES ('a', 2) ON DUPLICATE KEY UPDATE c2 = c2 + 1
, dondeon_duplicate_clause
serUPDATE c2 = c2 + 1
. Ver el Documentación de MySQL para encontrar quéon_duplicate_clause
se puede utilizar con elON DUPLICATE KEY
clausula.Especificar
on_duplicate_clause
tienes que pasar0
a lareplace_query
parámetro. Si pasa simultáneamentereplace_query = 1
yon_duplicate_clause
, ClickHouse genera una excepción.
Simple WHERE
cláusulas tales como =, !=, >, >=, <, <=
se ejecutan en el servidor MySQL.
El resto de las condiciones y el LIMIT
La restricción de muestreo se ejecuta en ClickHouse solo después de que finalice la consulta a MySQL.
Ejemplo de uso
Tabla en MySQL:
mysql> CREATE TABLE `test`.`test` (
-> `int_id` INT NOT NULL AUTO_INCREMENT,
-> `int_nullable` INT NULL DEFAULT NULL,
-> `float` FLOAT NOT NULL,
-> `float_nullable` FLOAT NULL DEFAULT NULL,
-> PRIMARY KEY (`int_id`));
Query OK, 0 rows affected (0,09 sec)
mysql> insert into test (`int_id`, `float`) VALUES (1,2);
Query OK, 1 row affected (0,00 sec)
mysql> select * from test;
+--------+--------------+-------+----------------+
| int_id | int_nullable | float | float_nullable |
+--------+--------------+-------+----------------+
| 1 | NULL | 2 | NULL |
+--------+--------------+-------+----------------+
1 row in set (0,00 sec)
Tabla en ClickHouse, recuperando datos de la tabla MySQL creada anteriormente:
CREATE TABLE mysql_table
(
`float_nullable` Nullable(Float32),
`int_id` Int32
)
ENGINE = MySQL('localhost:3306', 'test', 'test', 'bayonet', '123')
SELECT * FROM mysql_table
┌─float_nullable─┬─int_id─┐
│ ᴺᵁᴸᴸ │ 1 │
└────────────────┴────────┘