SELECT 和 INSERT 查询。
创建表
- 列名应与原始 MySQL 表中的列名一致,但也可以只使用其中部分列,且顺序可以任意。
- 列类型可以与原始 MySQL 表中的列类型不同。ClickHouse 会尝试将值 cast 为 ClickHouse 数据类型。
- external_table_functions_use_nulls 设置定义了如何处理 Nullable 列。默认值:1。如果为 0,表函数不会创建 Nullable 列,而是插入默认值来代替 null。这也适用于数组中的 NULL 值。
host:port— MySQL 服务器地址。database— 远程数据库名称。table— 远程表名。user— MySQL 用户。password— 用户密码。replace_query— 将INSERT INTO查询转换为REPLACE INTO的标志。如果replace_query=1,则会替换该查询。on_duplicate_clause— 添加到INSERT查询中的ON DUPLICATE KEY on_duplicate_clause表达式。 示例:INSERT INTO t (c1,c2) VALUES ('a', 2) ON DUPLICATE KEY UPDATE c2 = c2 + 1,其中on_duplicate_clause为UPDATE c2 = c2 + 1。请参阅 MySQL documentation,了解在ON DUPLICATE KEY子句中可以使用哪些on_duplicate_clause。 要指定on_duplicate_clause,需要向replace_query参数传递0。如果同时传递replace_query = 1和on_duplicate_clause,ClickHouse 会引发异常。
host 和 port。这种方式建议在生产环境中使用。
简单的 WHERE 子句 (如 =, !=, >, >=, <, <=) 会在 MySQL 服务器上执行。
其余条件以及 LIMIT 采样约束仅会在对 MySQL 的查询完成后由 ClickHouse 执行。
支持多个副本,必须使用 | 列出。例如:
使用示例
设置
connection_auto_close
- 1 — 允许自动关闭连接,因此会禁用连接复用
- 0 — 不允许自动关闭连接,因此会启用连接复用
1。
connection_max_tries
- 正整数。
- 0 — 启用故障转移的连接池不进行重试。
3。
connection_pool_size
- 正整数。
16。
connection_wait_timeout
connection_pool_size 个活动连接时) ,0 表示不等待。
可能的值:
- 正整数。
5。
connect_timeout
- 正整数。
10。
read_write_timeout
- 正整数。
300。