当前位置:网站首页>ClickHouse物化视图(八)
ClickHouse物化视图(八)
2022-08-09 11:13:00 【Java技术债务】
目录
概述
ClickHouse
的物化视图是一种查询结果的持久化,它确实是给我们带来了查询效率的提升。用户查起来跟表没有区别,它就是一张表,它也像是一张时刻在预计算的表,创建的过程它是用了一个特殊引擎,加上后来 as select,就是 create 一个 table as select 的写法。 “查询结果集”的范围很宽泛,可以是基础表中部分数据的一份简单拷贝,也可以是多表 join 之后产生的结果或其子集,或者原始数据的聚合指标等等。所以,物化视图不会随着基础表的变化而变化,所以它也称为快照(snapshot)
1 物化视图与普通视图的区别
- 普通视图:不保存数据,保存的仅仅是查询逻辑语句,查询的时候还是从原表读取数据,可以将普通视图理解为是个子查询。
- 物化视图:是把查询的结果根据相应的引擎存入到了磁盘或内存中,对数据重新进行了组织,你可以理解物化视图是完全的一张新表。
2 优缺点
- 优点:查询速度快,要是把物化视图这些规则全部写好,它比原数据查询快了很多,总的行数少了,因为都预计算好了。
- 缺点:它的本质是一个流式数据的使用场景,是累加式的技术,所以要用历史数据做去重、去核这样的分析,在物化视图里面是不太好用的。在某些场景的使用也是有限的。而且 如果一张表加了好多物化视图,在写这张表的时候,就会消耗很多机器的资源,比如数据带宽占满、存储一下子增加了很多。
3 基本语法
create 语法,会创建一个隐藏的目标表来保存视图数据。也可以 TO 表名,保存到一张显式的表。没有加 TO 表名,表名默认就是 .inner.物化视图名
CREATE [MATERIALIZED] VIEW [IF NOT EXISTS] [db.]table_name [TO[db.]name]
[ENGINE = engine] [POPULATE] AS SELECT ...
1) 创建物化视图的限制
- 必须指定物化视图的 engine 用于数据存储
- TO [db].[table]语法的时候,不得使用 POPULATE。 注意:使用此关键字会使历史的数据进行物化,而在创建物化视图的过程中同时写入的数据不能被插入物化视图
- 查询语句(select)可以包含下面的子句: DISTINCT, GROUP BY, ORDER BY, LIMIT…
- 物化视图的 alter 操作有些限制,操作起来不大方便。
- 若物化视图的定义使用了 TO [db.]name 子语句,则可以将目标表的视图卸载DETACH 再装载 ATTACH
2) 物化视图的数据更新
- 物化视图创建好之后,若源表被写入新数据则物化视图也会同步更新
POPULATE
关键字决定了物化视图的更新策略:- 若有关键字
POPULATE
则在创建视图的过程会将源表已经存在的数据一并导入,类似于create table ... as
- 若无
POPULATE
则物化视图在创建之后没有数据,只会在创建只有同步之后写入源表的数据 clickhouse
官方并不推荐使用POPULATE
,因为在创建物化视图的过程中同时写入的数据不能被插入物化视图。
- 若有关键字
- 物化视图不支持同步删除,若源表的数据不存在(删除了)则物化视图的数据仍然保留
- 物化视图是一种特殊的数据表,可以用 show tables 查看
4 物化视图创建示例
1) 建表
#建表语句
CREATE TABLE hits_test (
EventDate Date,
CounterID UInt32,
UserID UInt64,
URL String,
Income UInt8
)
ENGINE = MergeTree()
PARTITION BY toYYYYMM(EventDate)
ORDER BY (CounterID, EventDate, intHash32(UserID))
SAMPLE BY intHash32(UserID)
SETTINGS index_granularity = 8192
2) 模拟数据
INSERT INTO hits_test
SELECT
EventDate,
CounterID,
UserID,
URL,
IncomeFROM hits_v1
limit 10000;
3) **创建物化视图
#创建物化视图语句
CREATE MATERIALIZED VIEW hits_mv
ENGINE=SummingMergeTree
PARTITION BY toYYYYMM(EventDate) ORDER BY (EventDate, intHash32(UserID))
AS SELECT
UserID,
EventDate,
count(URL) as ClickCount,
sum(Income) AS IncomeSum
FROM hits_test
WHERE EventDate >= '2014-03-20' #设置更新点,该时间点之前的数据可以另外通过
#insert into select ...... 的方式进行插入
GROUP BY UserID,EventDate;
##或者可以用下列语法,表 A 可以是一张 mergetree 表 CREATE MATERIALIZED VIEW 物化视图名
##TO 表 A AS SELECT FROM 表 B;
#不建议添加 populate 关键字进行全量更新
4)导入数据
#导入增量数据
INSERT INTO hits_test SELECT
EventDate,CounterID,
UserID,
URL,
Income
FROM hits_v1
WHERE EventDate >= '2014-03-23'
limit 10;
5) 查询物化视图
SELECT * FROM hits_mv;
边栏推荐
- FreeRTOS任务创建源码分析
- Oracle数据库体系结构
- log4net使用指南(winform版,sqlserver记录)
- Antdv+Asp.net WebApi开发学生信息管理系统(一)
- golang源代码阅读,sync系列-Pool
- This application has no explicit mapping for /error, so you are seeing this as a fallback
- bit、byte、KB、M、G、T相互关系
- wpf实现简易画板功能(带截取画板,签名截图等等)
- Error: Cannot find module ‘./application‘
- Cesium加载三维模型数据
猜你喜欢
fork创建多个子进程
x86 Exception Handling and Interrupt Mechanism (1) Overview of the source and handling of interrupts
fidder为什么不会抓包的问题
ICML 2022 | Out-of-Distribution检测与深最近的邻居
End-to-End Object Detection with Fully Convolutional Network学习笔记
【VIBE: Video Inference for Human Body Pose and Shape Estimation】论文阅读
【Subpixel Dense Refinement Network for Skeletonization】CVPR2020论文解读
ECCV 2022 Oral | CCPL: 一种通用的关联性保留损失函数实现通用风格迁移
Cesium加载三维模型数据
∘(空心的点乘)的数学含义
随机推荐
Julia资料收集
wait系统调用
es6对象迭代器iterator
redis的缓存穿透、缓存雪崩、缓存击穿怎么搞?
The use of C language typedef 】 : structure, basic data types, and array
PAT1008
MATLAB中如何把cftool拟合的函数输出到命令行(解决如何导出拟合后的曲线数据)
Looper 原理浅析
PAT1009
vite的原理,手写vite
wait system call
UNIX哲学
Notepad++安装插件
redis的线程模型
PTA习题 阶梯电价(C)
mysql参数学习----max_allowed_packet
[现代控制理论]6_稳定性_李雅普诺夫_Lyapunov
fork创建多个子进程
CentOS6.5 32bit安装Oracle、ArcSde、Apache等配置说明
UNIX Philosophy