MySQL表引擎可以与MySQL数据库中的数据表简历映射,并通过SQL向其发起远程查询。

MySQL表引擎可以与物化视图结合,来同步更新MySQL数据库中的数据。

语法:
CREATE TABLE [IF NOT EXISTS] [db.]table_name [ON CLUSTER cluster]
(
name1 [type1] [DEFAULT|MATERIALIZED|ALIAS expr1] [TTL expr1],
name2 [type2] [DEFAULT|MATERIALIZED|ALIAS expr2] [TTL expr2],
...
) ENGINE = MySQL('host:port', 'database', 'table', 'user', 'password'[, replace_query, 'on_duplicate_clause']); 解释:
host:port MySQL服务器的地址和端口
database MySQL中的数据库名
table 表示需要映射的MySQL表名称
user mysql的用户名
password mysql的用户名对应的密码
replace_query 默认为0,对应于MySQL的REPLACE INTO 语法;若为1则会用replace into 代替insert into
on_duplicate_clause 默认为0 对应MySQL的 ON DUPLICATE KEY语法,若需要使用该设置则必须将replace——query 设置为0.

示例:

-- 1. 在MySQL中创建表定义和加入数据:
mysql> select version();
+-----------+
| version() |
+-----------+
| 8.0.20 |
+-----------+
1 row in set (0.01 sec)
mysql> show create table t_org\G
*************************** 1. row ***************************
Table: t_org
Create Table: CREATE TABLE `t_org` (
`ID` int NOT NULL AUTO_INCREMENT,
`org_code` varchar(8) DEFAULT NULL,
`org_name` varchar(32) DEFAULT NULL,
`lastmodifytime` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
1 row in set (0.00 sec) 插入数据:
insert into t_org(org_code,org_name)values('A01','研发部'),('A02','产品部'),('A03','测试部'),('A04','数据部'),('A05','运维部');

2.在clickhouse中对MySQL表引擎建立映射:
Clickhouse> create table t_org(ID UInt32,org_code String,org_name String,LASTMODIFYTIME Datetime)ENGINE=MySQL('192.168.8.110:3306','datasets','t_org','root','oracle'); CREATE TABLE t_org
(
`ID` UInt32,
`org_code` String,
`org_name` String,
`LASTMODIFYTIME` Datetime
)
ENGINE = MySQL('192.168.8.110:3306', 'datasets', 't_org', 'root', 'oracle') Ok. 0 rows in set. Elapsed: 0.002 sec. 注意:
1.MySQL 中的Decimal(p,s) 类型在Clickhouse中的定义的差异
2.clickhouse的数据库引擎 ENGINE = MySQL 这里的MySQL必须要是MySQL
否则报错信息:
Received exception from server (version 20.4.5):
Code: 56. DB::Exception: Received from localhost:9000. DB::Exception: Unknown table engine Mysql. Maybe you meant: ['MySQL']. 查看表的定义:
Clickhouse> desc t_org; DESCRIBE TABLE t_org ┌─name───────────┬─type─────┬─default_type─┬─default_expression─┬─comment─┬─codec_expression─┬─ttl_expression─┐
│ ID │ UInt32 │ │ │ │ │ │
│ org_code │ String │ │ │ │ │ │
│ org_name │ String │ │ │ │ │ │
│ LASTMODIFYTIME │ DateTime │ │ │ │ │ │
└────────────────┴──────────┴──────────────┴────────────────────┴─────────┴──────────────────┴────────────────┘ 4 rows in set. Elapsed: 0.002 sec.
-- 查询clickhouse的定义:
Clickhouse> select * from t_org; SELECT *
FROM t_org ┌─ID─┬─org_code─┬─org_name─┬──────LASTMODIFYTIME─┐
│ 1 │ A01 │ 研发部 │ 2020-07-06 15:13:46 │
│ 2 │ A02 │ 产品部 │ 2020-07-06 15:13:46 │
│ 3 │ A03 │ 测试部 │ 2020-07-06 15:13:46 │
│ 4 │ A04 │ 数据部 │ 2020-07-06 15:13:46 │
│ 5 │ A05 │ 运维部 │ 2020-07-06 15:13:46 │
└────┴──────────┴──────────┴─────────────────────┘ 5 rows in set. Elapsed: 0.007 sec.
在MySQL 中插入新的数据:
insert into t_org(org_code,org_name)values('A06','销售部'),('A07','人力部'); 在clickhouse中查询:
Clickhouse> select * from t_org; SELECT *
FROM t_org ┌─ID─┬─org_code─┬─org_name─┬──────LASTMODIFYTIME─┐
│ 1 │ A01 │ 研发部 │ 2020-07-06 15:13:46 │
│ 2 │ A02 │ 产品部 │ 2020-07-06 15:13:46 │
│ 3 │ A03 │ 测试部 │ 2020-07-06 15:13:46 │
│ 4 │ A04 │ 数据部 │ 2020-07-06 15:13:46 │
│ 5 │ A05 │ 运维部 │ 2020-07-06 15:13:46 │
│ 6 │ A06 │ 销售部 │ 2020-07-06 15:22:28 │
│ 7 │ A07 │ 人力部 │ 2020-07-06 15:22:28 │
└────┴──────────┴──────────┴─────────────────────┘ 7 rows in set. Elapsed: 0.005 sec. 数据已经和MySQL中的数据一样。 在MySQL中更新数据:
mysql> update t_org set org_name='财务部' where org_code='A07';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0 mysql> select * from t_org;
+----+----------+-----------+---------------------+
| ID | org_code | org_name | lastmodifytime |
+----+----------+-----------+---------------------+
| 1 | A01 | 研发部 | 2020-07-06 15:13:46 |
| 2 | A02 | 产品部 | 2020-07-06 15:13:46 |
| 3 | A03 | 测试部 | 2020-07-06 15:13:46 |
| 4 | A04 | 数据部 | 2020-07-06 15:13:46 |
| 5 | A05 | 运维部 | 2020-07-06 15:13:46 |
| 6 | A06 | 销售部 | 2020-07-06 15:22:28 |
| 7 | A07 | 财务部 | 2020-07-06 15:24:10 |
+----+----------+-----------+---------------------+
7 rows in set (0.00 sec)
在Clickhouse中查询:
Clickhouse> select * from t_org; SELECT *
FROM t_org ┌─ID─┬─org_code─┬─org_name─┬──────LASTMODIFYTIME─┐
│ 1 │ A01 │ 研发部 │ 2020-07-06 15:13:46 │
│ 2 │ A02 │ 产品部 │ 2020-07-06 15:13:46 │
│ 3 │ A03 │ 测试部 │ 2020-07-06 15:13:46 │
│ 4 │ A04 │ 数据部 │ 2020-07-06 15:13:46 │
│ 5 │ A05 │ 运维部 │ 2020-07-06 15:13:46 │
│ 6 │ A06 │ 销售部 │ 2020-07-06 15:22:28 │
│ 7 │ A07 │ 财务部 │ 2020-07-06 15:24:10 │
└────┴──────────┴──────────┴─────────────────────┘ 7 rows in set. Elapsed: 0.003 sec.
通过clickhouse查询远程的数据 可以看到数据一样发生了变化。 ---delete 操作:
mysql> delete from t_org where org_code='A07';
Query OK, 1 row affected (0.00 sec) mysql> select * from t_org where org_code='A07';
Empty set (0.00 sec) Clickhouse> select * from t_org; SELECT *
FROM t_org ┌─ID─┬─org_code─┬─org_name─┬──────LASTMODIFYTIME─┐
│ 1 │ A01 │ 研发部 │ 2020-07-06 15:13:46 │
│ 2 │ A02 │ 产品部 │ 2020-07-06 15:13:46 │
│ 3 │ A03 │ 测试部 │ 2020-07-06 15:13:46 │
│ 4 │ A04 │ 数据部 │ 2020-07-06 15:13:46 │
│ 5 │ A05 │ 运维部 │ 2020-07-06 15:13:46 │
│ 6 │ A06 │ 销售部 │ 2020-07-06 15:22:28 │
└────┴──────────┴──────────┴─────────────────────┘ 6 rows in set. Elapsed: 0.004 sec. --- 使用雾化视图: Clickhouse> create materialized view mv_t_org engine=MergeTree() order by ID as select * from t_org; CREATE MATERIALIZED VIEW mv_t_org
ENGINE = MergeTree()
ORDER BY ID AS
SELECT *
FROM t_org Ok. 0 rows in set. Elapsed: 0.004 sec.

结论:ClickHouse暂时不支持通过ClickHouse 的MySQL引擎表更新和删除操作,他们之间的关系如下:

ClickHouse的物化视图及MySQL表引擎的更多相关文章

  1. mysql表引擎myisam改为innodb

    1.进入数据库 2.SELECT  CONCAT('ALTER TABLE `', table_name, '` ENGINE=InnoDB;') AS sql_statements FROM    ...

  2. Mysql表引擎的切换

    转换MYSQL表的引擎 1.方法一:Alter table 将1个表的引擎修改为另一个引擎最简单的方法是使用Alter table语句. 下面的语句将myTable的引擎修改为InnoDB mysql ...

  3. mysql 视图 安全性( mysql 表能读,但是视图不能读问题 )

    安全性: 有两个选项 Definer:定义者 , 定义者有什么权限 ,访问视图的人就有什么权限 Invoker: 调用者  ,根据调用这个视图的当前用户来决定 有什么权限 采坑: 项目中有个复杂查询. ...

  4. ClickHouse性能优化?试试物化视图

    一.前言 ClickHouse是一个用于联机分析(OLAP)的列式数据库管理系统(DBMS):目前我们使用CH作为实时数仓用于统计分析,在做性能优化的时候使用了 物化视图 这一特性作为优化手段,本文主 ...

  5. clickhouse物化视图

    今天来简单介绍一下clickhouse的物化视图 物化视图支持表引擎,数据保存形式由它的表引擎决定,创建物化视图的完整语法如下: create materialized view mv_log eng ...

  6. MySQL进阶实战6,缓存表、视图、计数器表

    一.缓存表和汇总表 有时提升性能最好的方法是在同一张表中保存衍生的冗余数据,有时候还需要创建一张完全独立的汇总表或缓存表. 缓存表用来存储那些获取很简单,但速度较慢的数据: 汇总表用来保存使用grou ...

  7. Oracle 10g通过创建物化视图实现不同数据库间表级别的数据同步

    摘自:http://blog.csdn.net/javaee_sunny/article/details/53439980 目录(?)[-] Oracle 10g 物化视图语法如下 实例演示 主要步骤 ...

  8. Oracle之物化视图

    来源于:http://www.cnblogs.com/Ronger/archive/2012/03/28/2420962.html 近期根据项目业务需要对oracle的物化视图有所接触,在网上搜寻关于 ...

  9. 《oracle每天一练》Oracle之物化视图

    相关帖子思考和跟踪 本文转自Ronger 物化视图是一种特殊的物理表,“物化”(Materialized)视图是相对普通视图而言的.普通视图是虚拟表,应用的局限性大,任何对视图的查询,Oracle都实 ...

  10. 物化视图刷新慢--有可能是mv log被多个mv使用造成的

    同事说物化视图刷新慢,经检生产环境,发现部分物化视图刷新慢的原因是:由于同一个物化视图日志(mv log)被多个物化视图(mv)使用,不同的物化视图(mv)使用不同的刷新间隔,导致物化视图日志(mv ...

随机推荐

  1. WPF 简单实现一个支持删除自身的应用

    我准备写一个逗比的应用,然而我担心被小伙伴看到这个应用的文件从而知道是我写的,于是我就需要实现让应用能自删除的功能.核心实现方法就是调用 cmd 传入命令行,等待几秒之后删除文件 应用程序在运行时,是 ...

  2. WPF 漂亮的现代化控件 新 ModernWPF 界面库

    这是一个在 GitHub 上完全开源的库,有十分漂亮的界面,整个都是 Win10 风,界面部分和默认 UWP 相近 这个库支持了 .NET Framework 4.5 和以上的版本,以及 .NET C ...

  3. computed计算属性和watch的区别:

    计算 ' 单价 x 数量 = 总价 ' watch:就不写了,没意思 computed: computed:{ allPrice:function(){ return this.price*this. ...

  4. 简说Python之循环语句

    目录 Python的运算逻辑 Python条件语句 Python循环语句 Python while循环 Python for 循环 条件语句和循环语句是程序常用的一种基础语法,从语言上来说,能说清楚的 ...

  5. postgresql性能优化1:min和max的性能

    select max(datatime) as id from mytable ---全表检索,时间慢执行时间5分钟 select max(datatime) as id from mytable w ...

  6. kettle使用1-全表导入

    1.新建转换 2.DB连接中,新建数据库连接 3.在输入中,选择表输入 选择连接的数据库和查询的sql的数据 4.再输出中,选择表输出 5.按住shift,建立数据连接 6.匹配数据字段映射

  7. pageoffice在线编辑word文件并禁止选中

    一.整篇文档禁止选中 wordDoc.setDisableWindowSelection(true); //禁止word的选择文字功能 二.根据条件判断是否禁止选中 比如:选中内容超过一定字数,取消选 ...

  8. 智能制造 | AIRIOT智慧工厂管理解决方案

      工厂生产运转中,设备数量多,环境复杂.企业往往需要承担很高的维修.保养.备件和人力成本.传统的工厂改革遇到了诸多前所未有的挑战:   1.管理系统较多,数据隔离,系统集成困难重重: 2.大量老旧设 ...

  9. WPF 制作高性能的透明背景异形窗口(使用 WindowChrome 而不要使用 AllowsTransparency=True)

    在 WPF 中,如果想做一个背景透明的异形窗口,基本上都要设置 WindowStyle="None".AllowsTransparency="True" 这两个 ...

  10. 申请并部署免费的 SSL/TLS 证书

    对于囊中羞涩的我们来说,只要能白嫖,就绝不乱花钱.惯常申请免费 SSL/TLS 证书的途径有: 各大云服务平台限量提供.比如阿里云会给每个账号每年 20 个证书的申请额度.缺点是不支持泛域名,一年后须 ...