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

将 MySQL 与 ClickHouse 集成

本页介绍如何使用 MySQL 表引擎从 MySQL 表中读取数据

使用 MySQL 表引擎连接 ClickHouse 到 MySQL

MySQL 表引擎允许您将 ClickHouse 连接到 MySQL。可以在 ClickHouse 或 MySQL 表中执行 SELECTINSERT 语句。本文说明了如何使用 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. 请注意,来自 MySQL 表的现有行已在 ClickHouse 表中,以及您刚刚添加的新行
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 表引擎 的文档页面。