用户使用的所有表都是由数据库引擎所提供的。默认情况下,clickhouse使用自己的数据库引擎,该引擎提供可配置的表引擎。除此之外,可以选择的数据库引擎包括:MySQL,Lazy
1.Atomic
默认情况下使用Atomic引擎。
CREATE DATABASE test ENGINE = Atomic;
支持非阻塞Drop和Rename table查询以及原子exchange tables t1 and t2查询
2.Lazy
延时引擎,在距最近一次访问间隔expiration_time_in_seconds时间段内,将表保存在内存中,仅适用于*Log引擎表。由于针对这类表的访问间隔较长,对保存大量小的*Log引擎表进行了优化。
CREATE DATABASE testlazy ENGINE = Lazy(expiration_time_in_seconds);
3.MySQL
该引擎用于将远程的MySQL服务器中的表映射到Clickhouse中,并允许你对表进行insert和select查询,以方便用户在clickhouse和MySQL之间进行数据交换。
MySQL数据库引擎会将用户对其的查询转化为MySQL语法并发送到MySQL服务器中,因此用户可以执行诸如show tables或show create table之类的操作。
但无法对其执行以下操作:
rename、create table、alter
CREATE DATABASE [IF NOT EXISTS] db_name [ON CLUSTER cluster]
ENGINE = MySQL('host:port', ['database' | database], 'user', 'password')
- host:port---链接的MySQL地址
- database--链接的MySQL数据库
- user--链接的MySQL用户
- password--链接的MySQL用户密码
支持的类型对应
MySQL | clickhouse |
UNSIGNED TINYINT | UInt8 |
TINYINT | Int8 |
UNSIGNED SMALLINT | UInt16 |
SMALLINT | Int16 |
UNSIGNED INT, UNSIGNED MEDIUMINT | UInt32 |
INT, MEDIUMINT | Int32 |
UNSIGNED BIGINT | UInt64 |
BIGINT | Int64 |
FLOAT | Float32 |
DOUBLE | Float64 |
DATE | 日期 |
DATETIME, TIMESTAMP | 日期时间 |
BINARY | 固定字符串 |
其他的MySQL数据类型将全部转换为字符串,且以上所有类型都支持可为空。
使用示例
1)MySQL中创建表
mysql> USE test;
Database changed
mysql> CREATE TABLE `mysql_table` (
-> `int_id` INT NOT NULL AUTO_INCREMENT,
-> `float` FLOAT NOT NULL,
-> PRIMARY KEY (`int_id`));
Query OK, 0 rows affected (0,09 sec)
mysql> insert into mysql_table (`int_id`, `float`) VALUES (1,2);
Query OK, 1 row affected (0,00 sec)
mysql> select * from mysql_table;
+--------+-------+
| int_id | value |
+--------+-------+
| 1 | 2 |
+--------+-------+
1 row in set (0,00 sec)
2)clickhouse创建MySQL类型的数据库,并与MySQL服务器交换数据
CREATE DATABASE mysql_db ENGINE = MySQL('localhost:3306', 'test', 'my_user', 'user_password')
3)clickhouse端查看数据库、表
SHOW DATABASES
┌─name─────┐
│ default │
│ mysql_db │
│ system │
└──────────┘
SHOW TABLES FROM mysql_db
┌─name─────────┐
│ mysql_table │
4)clickhouse端查看数据
SELECT * FROM mysql_db.mysql_table
┌─int_id─┬─value─┐
│ 1 │ 2 │
└────────┴───────┘
5)clickhouse端插入数据再查看
INSERT INTO mysql_db.mysql_table VALUES (3,4)
SELECT * FROM mysql_db.mysql_table
┌─int_id─┬─value─┐
│ 1 │ 2 │
│ 3 │ 4 │