[go: up one dir, main page]

跳到主要内容
跳到主要内容

将 MySQL 与 ClickHouse 集成

本页介绍了使用 MySQL 表引擎从 MySQL 表读取数据。

备注

对于 ClickHouse Cloud,您还可以使用 MySQL ClickPipe(目前处于公开测试阶段)轻松将数据从您的 MySQL 表移动到 ClickHouse。

使用 MySQL 表引擎将 ClickHouse 连接到 MySQL

MySQL 表引擎允许您将 ClickHouse 连接到 MySQL。SELECTINSERT 语句可以在 ClickHouse 或 MySQL 表中执行。本文描述了如何使用 MySQL 表引擎的基本方法。

1. 配置 MySQL

  1. 在 MySQL 中创建一个数据库:
CREATE DATABASE db1;
  1. 创建一个表:
CREATE TABLE db1.table1 (
  id INT,
  column1 VARCHAR(255)
);
  1. 插入示例行:
INSERT INTO db1.table1
  (id, column1)
VALUES
  (1, 'abc'),
  (2, 'def'),
  (3, 'ghi');
  1. 创建一个连接 ClickHouse 的用户:
CREATE USER 'mysql_clickhouse'@'%' IDENTIFIED BY 'Password123!';
  1. 根据需要授予权限。(出于演示目的,mysql_clickhouse 用户被授予管理员权限。)
GRANT ALL PRIVILEGES ON *.* TO 'mysql_clickhouse'@'%';
备注

如果您在 ClickHouse Cloud 中使用此功能,您可能需要允许 ClickHouse Cloud 的 IP 地址访问您的 MySQL 实例。 请查看 ClickHouse Cloud Endpoints API 以获取出站流量的详细信息。

2. 在 ClickHouse 中定义一个表

  1. 现在让我们创建一个使用 MySQL 表引擎的 ClickHouse 表:
CREATE TABLE mysql_table1 (
  id UInt64,
  column1 String
)
ENGINE = MySQL('mysql-host.domain.com','db1','table1','mysql_clickhouse','Password123!')

最低参数要求如下:

参数描述示例
host主机名或 IPmysql-host.domain.com
databasemysql 数据库名称db1
tablemysql 表名称table1
user用于连接 MySQL 的用户名mysql_clickhouse
password用于连接 MySQL 的密码Password123!
备注

查看 MySQL 表引擎 文档页面以获取完整的参数列表。

3. 测试集成

  1. 在 MySQL 中插入一行示例数据:
INSERT INTO db1.table1
  (id, column1)
VALUES
  (4, 'jkl');
  1. 注意 ClickHouse 表中存在来自 MySQL 表的行,以及您刚刚添加的新行:
SELECT
    id,
    column1
FROM mysql_table1

您应该会看到 4 行:

Query id: 6d590083-841e-4e95-8715-ef37d3e95197

┌─id─┬─column1─┐
│  1 │ abc     │
│  2 │ def     │
│  3 │ ghi     │
│  4 │ jkl     │
└────┴─────────┘

4 rows in set. Elapsed: 0.044 sec.
  1. 让我们在 ClickHouse 表中添加一行:
INSERT INTO mysql_table1
  (id, column1)
VALUES
  (5,'mno')
  1. 注意新行出现在 MySQL 中:
mysql> select id,column1 from db1.table1;

您应该会看到新行:

+------+---------+
| id   | column1 |
+------+---------+
|    1 | abc     |
|    2 | def     |
|    3 | ghi     |
|    4 | jkl     |
|    5 | mno     |
+------+---------+
5 rows in set (0.01 sec)

总结

MySQL 表引擎允许您将 ClickHouse 连接到 MySQL,双向交换数据。有关更多详细信息,请务必查看 MySQL 表引擎 的文档页面。