clickhouse9--数据库引擎

        用户使用的所有表都是由数据库引擎所提供的。默认情况下,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用户密码

支持的类型对应

MySQLclickhouse
UNSIGNED TINYINTUInt8
TINYINTInt8
UNSIGNED SMALLINTUInt16
SMALLINTInt16
UNSIGNED INT, UNSIGNED MEDIUMINTUInt32
INT, MEDIUMINTInt32
UNSIGNED BIGINTUInt64
BIGINTInt64
FLOATFloat32
DOUBLEFloat64
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 │

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值