首页 > 其他分享 >ClickHouse 物化视图

ClickHouse 物化视图

时间:2022-12-21 10:22:51浏览次数:40  
标签:hits UserID 视图 物化 数据 EventDate ClickHouse

ClickHouse的物化视图是一种查询结果的持久化,它确实是给我们带来了查询效率的提升。用户查起来跟表没有区别,它就是一张表,它也像是一张时刻在预计算的表,创建的过程它是用了一个特殊引擎,加上后来 as select,就是create一个table as select的写法。“查询结果集”的范围很宽泛,可以是基础表中部分数据的一份简单拷贝,也可以是多表join之后产生的结果或其子集,或者原始数据的聚合指标等等。所以,物化视图不会随着基础表的变化而变化,所以它也称为快照(snapshot).

1、概述

1.1、物化视图和普通视图区别

普通视图不保存数据,保存的仅仅是查询语句,查询的时候还是从原表读取数据,可以将普通视图理解为是个子查询。物化视图则是把查询的结果根据相应的引擎存入到了磁盘或内存中,对数据重新进行了组织,你可以理解物化视图是完全的一张新表。

1.2、优缺点

  • 优点:查询速度快,要是把物化视图这些规则全部写好,它比原数据查询快了很多,总的行数少了,因为都预计算好了。
  • 缺点:它的本质是一个流式数据的使用场景,是累加式的技术,所以要用历史数据做去重、去核这样的分析,在物化视图里面是不太好用的。在某些场景的使用也是有限的。而且如果一张表加了好多物化视图,在写这张表的时候,就会消耗很多机器的资源,比如数据带宽占满、存储一下子增加了很多。

1.3 基本语法

也是create语法,会创建一个隐藏的目标表来保存视图数据。也可以TO 表名,保存到一张显式的表。没有加TO表名,表名默认就是 .inner.物化视图名;
CREATE [MATERIALIZED] VIEW [IF NOT EXISTS] [db.]table_name [TO[db.]name] [ENGINE = engine] [POPULATE] 
AS SELECT ...
创建物化视图的限制 1.必须指定物化视图的engine 用于数据存储 2.TO [db].[table]语法的时候,不得使用POPULATE。 3.查询语句(select)可以包含下面的子句: DISTINCT, GROUP BY, ORDER BY, LIMIT… 4.物化视图的alter操作有些限制,操作起来不大方便。 5.若物化视图的定义使用了TO [db.]name 子语句,则可以将目标表的视图 卸载 DETACH 再装载 ATTACH 物化视图的数据更新 (1)物化视图创建好之后,若源表被写入新数据则物化视图也会同步更新 (2)POPULATE 关键字决定了物化视图的更新策略: 若有POPULATE 则在创建视图的过程会将源表已经存在的数据一并导入,类似于 create table ... as 若无POPULATE 则物化视图在创建之后没有数据,只会在创建只有同步之后写入源表的数据 clickhouse 官方并不推荐使用POPULATE,因为在创建物化视图的过程中同时写入的数据不能被插入物化视图。 (3)物化视图不支持同步删除,若源表的数据不存在(删除了)则物化视图的数据仍然保留 (4)物化视图是一种特殊的数据表,可以用show tables 查看 (5)物化视图数据的删除: (6)物化视图的删除:

2、物化视图应用

2.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
导入一些数据
INSERT INTO hits_test
    SELECT
    EventDate,
    CounterID,
    UserID,
    URL,
    Income
FROM datasets.hits_v1
limit 10000;

2.2 创建物化视图

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'
GROUP BY UserID,EventDate;

##或者可以用下列语法,表A可以是一张mergetree表
CREATE MATERIALIZED VIEW 物化视图名 TO 表A
AS SELECT FROM 表B;
 
#不建议添加populate关键字进行全量更新

2.3 导入增量数据

#导入增量数据
INSERT INTO hits_test
SELECT
    EventDate,
    CounterID,
    UserID,
    URL,
    Income
FROM datasets.hits_v1
WHERE EventDate >= '2014-03-23'
limit 10;
#查询物化视图
SELECT * FROM hits_mv;
8585742290196126178    2014-03-23    8    16
1095363898647626948    2014-03-23    2    0

2.4 导入历史数据

#导入增量数据
INSERT INTO hits_mv
SELECT
    UserID,
    EventDate,
    count(URL) as ClickCount,
    sum(Income) AS IncomeSum
FROM  hits_test
WHERE EventDate = '2014-03-20'
GROUP BY UserID,EventDate

#查询物化视图
SELECT * FROM hits_mv;

标签:hits,UserID,视图,物化,数据,EventDate,ClickHouse
From: https://www.cnblogs.com/wdh01/p/16879914.html

相关文章

  • $set解决vue中修改数组或对象视图不更新的问题,uniapp应用vue2也会有同样的问题
    相信大家和我一样,在开发中总是遇到一个问题。为啥我修改v-for遍历的数组,视图却没有更新???当我点击其他操作重新渲染后,又更新了???这不会是vue出bug了吧这项问题其实正是由vue......
  • 故障分析 | ClickHouse 物化视图插入时间变为“1970-01-01 08:00:00”问题复盘
    作者:大睿大睿,DBA,爱好减肥,瘦了30多斤,负责公司数据库集群的管理和维护。物化视图使用​​to​​的方式写入到存储表中,即如下:CREATEMATERIALIZEDVIEW[IFNOTEXISTS][db.]tab......
  • 分布式 | DBLE 是如何实现视图的?
    作者:苏仕祥浩鲸科技PaaS组件团队成员,长期从事分库分表中间件的相关解决方案工作,热爱技术,乐于分享。本文来源:原创投稿*爱可生开源社区出品,原创内容未经授权不得随意使用,转......
  • MAUI新生4.1-控件视图:控件总览(未完待续)
    根据控件的功能特点,以及个人的习惯,我将MAUI的控件划分为以下几个大类:Page页面类Layout布局类Content单一内容类Collection集合内容类Form表单类Shape形状类辅助功......
  • DRF视图集中添加其他API--@action装饰器
    问题:DRF视图集中若想添加其他API?通过给视图集中的函数,添加DRF的@action()装饰器DRF的@action装饰器,用来为函数添加路由,主要参数有:methods:支持的请求方式,值为一个列表,默......
  • 视图
    含义:虚拟表,和普通表一样使用比如:舞蹈班和普通班的对比#案例:查询姓张的学生名和专业名selectstuname,majornamefromstuinfosinnerjoinmajormons.majorid=m.i......
  • 5.6.2 视图空间
    为了形成定义场景的2D图像,我们必须将虚拟相机放在场景中。相机指定了观众可以看到的世界体积,因此通过这个世界的体积生成我们需要的2D图像。让我们定义局部坐标系统(称为视图......
  • 3Dmax界面_视图调整
    一.试图模型显示效果的切换'默认是真实显示效果'线框模式 快捷键F3 ---->真实显示效果和线框显示效果的切换(切换到线框显示效果再按F3就切换到了真实显示效果)。线面......
  • 企业级自定义表单引擎解决方案(十八)--列表视图属性设置
    表格对于后台管理类的系统来说,至关重要,系统大多数功能都需要以表格的方式展示业务内容,系统开发人员多数时间也是围绕着表格进行业务编码,接触过很多后台管理系统的框架,我个......
  • DRF之视图
    视图两个视图基类APIViewGenericAPIViewAPIView:APIView是RESTframework提供的所有视图的基类,继承自Django的View父类APIView与View的不同之处在于-......