百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

金仓数据库物化视图学习

wptr33 2025-02-07 19:20 15 浏览

1. 物化视图介绍

对于普通视图而言,数据会存储在基表中,这导致每次查询都相当于执行了视图定义的SELECT语句。对于物化视图而言,数据会进行单独存储,这导致物化视图的查询是对存储数据直接访问(省去了连接运算)。下面对KingbaseES物化视图的使用进行介绍。

2. CREATE MATERIALIZED VIEW

CREATE MATERIALIZED VIEW语句被用来创建一个物化视图。创建物化视图时可以指定物化视图的刷新方式,CREATE MATERIALIZED VIEW主要语法如下:

CREATE MATERIALIZED VIEW [ IF NOT EXISTS ] table_name

[ (column_name [, ...] ) ]

[ USING method ]

[ WITH ( storage_parameter [= value] [, ... ] ) ]

[ TABLESPACE tablespace_name ]

AS query

[ WITH [ NO ] DATA ]

KingbaseES在Oracle模式可以指定刷新方式,并支持以下语法:

CREATE MATERIALIZED VIEW LOG ON table_name

[WITH {CTID | PRIMARY KEY | ROWID}]


CREATE MATERIALIZED VIEW [ IF NOT EXISTS ] table_name

[ (column_name [, ...] ) ]

[ USING method ]

[ WITH ( storage_parameter [= value] [, ... ] ) ]

[ TABLESPACE tablespace_name ]

[NEVER REFRESH |

REFRESH {[ FAST | COMPLETE | FORCE ] | ON {DEMAND | COMMIT} |

WITH {CTID | PRIMARY KEY | ROWID}}]

AS query

[ WITH [ NO ] DATA ]

需要注意的是,KingbaseES当前对commit刷新只做了语法兼容,并不支持其功能。

示例:创建简单的物化视图

--创建基表

create table base1(id int, name text);

create table base2(id int, birthday text);


--创建物化视图

CREATE MATERIALIZED VIEW mymatview AS SELECT base1.id id,name,birthday FROM base1, base2 where base1.id = base2.id;


示例:在创建时填充数据

--基表插入数据

INSERT INTO base1 values(1,'TOM');

INSERT INTO base2 values(1,'2020-01-01');


--创建物化视图,填充数据

CREATE MATERIALIZED VIEW mymatview1 AS SELECT base1.id id,name,birthday FROM base1, base2 where base1.id = base2.id;


--查询物化视图

Select * from mymatview1;


示例:创建时不填充数据,后续刷新物化视图填充

--创建物化视图,不填充数据

CREATE MATERIALIZED VIEW mymatview2 AS SELECT base1.id id,name,birthday FROM base1, base2 where base1.id = base2.id with no data;


--查询物化视图

Select * from mymatview2;


--物化视图刷新后,可以正常显示数据

REFRESH MATERIALIZED VIEW mymatview2;

Select * from mymatview2;


示例:物化视图指定刷新方式

--创建物化视图,指定全量刷新

CREATE MATERIALIZED VIEW mymatview3 REFRESH COMPLETE AS SELECT base1.id id,name,birthday FROM base1, base2 where base1.id = base2.id with no data;


--创建物化视图时,无物化日志时不能指定增量刷新

CREATE MATERIALIZED VIEW mymatview4 REFRESH Fast AS SELECT base1.id id,name,birthday FROM base1, base2 where base1.id = base2.id;


--创建物化视图时,指定默认的刷新方式

CREATE MATERIALIZED VIEW mymatview4 REFRESH FORCE AS SELECT base1.id id,name,birthday FROM base1, base2 where base1.id = base2.id;


--当前创建物化视图时, 不支持commit的刷新方式

CREATE MATERIALIZED VIEW mymatview5 REFRESH ON COMMIT FORCE AS SELECT base1.id id,name,birthday FROM base1, base2 where base1.id = base2.id;


--创建物化视图,指定DEMAND刷新

CREATE MATERIALIZED VIEW mymatview5 REFRESH ON DEMAND FORCE AS SELECT base1.id id,name,birthday FROM base1, base2 where base1.id = base2.id;



3. REFRESH MATERIALIZED VIEW

在上面的示例中,我们已经创建了物化视图,当基表数据发生变化时,物化视图就需要刷新,否则就无法获取物化视图中的数据。物化视图的刷新命令为REFRESH MATERIALIZED VIEW,具体语法如下:

REFRESH MATERIALIZED VIEW [ CONCURRENTLY ] name

[ WITH [ NO ] DATA ]

示例:基表数据变化后,物化视图将不可见

--对基表添加数据

INSERT INTO base1 values(2,'john');

INSERT INTO base2 values(2,'2021-01-01');


--未刷新时查询物化视图,发现数据没有同步更新

Select * from mymatview1;


--刷新后,新插入的数据可以获取

REFRESH MATERIALIZED VIEW mymatview1;

Select * from mymatview1;


--使用with no data刷新,将导致视图无法被访问

REFRESH MATERIALIZED VIEW mymatview1 with no data;

Select * from mymatview1;


相关推荐

时尚芭莎90秒|不是人造,我不要

各位网友大家好,欢迎来到时尚芭莎90秒!仙女们,过冬御寒的保暖单品备好了吗?在当下更讲究环保和人道主义的风向下,一件魅力不减的人造皮单品必须要加进你的必败清单,不是人造的,我可不穿。...

Apex Stand三合一支架:简洁便携设计, 拯救你的桌面

这次体验的这款手机、平板、笔电三合一支架ApexStand或许可以帮你解决设备太多导致桌面太过凌乱的问题。ApexStand采用可折叠的设计,并且还配有收纳袋,这一切都给与了ApexStand优...

每日一荐:把iPad变成电视你觉得如何

iPad的屏幕尺寸介于大屏手机和笔记本电脑之间,怪异,但用途广泛。外设厂商在不遗余力地设计制造各种小玩意来妆点这块小平板,以致于有人将iPad折腾成了一个“复古电视”,这个创意你喜欢吗?这个小配件名为...

Standalone是什么?Standalone集群的三类进程

Standalone是什么Standalone模式是Spark自带的一种集群模式,不同于前面本地模式启动多个进程来模拟集群的环境,Standalone模式是真实地在多个机器之间搭建Spark集群的环境...

坚守与支撑 - Hold Up and Stand Firm

Inlife'sjourney,theconceptof"holdup"playsavitalrole."Holdup"canme...

当齐秦翻唱英文神曲,这版《Stand By Me》直接唱进灵魂深处!

是一首英文歌曲,是我比较喜欢的一首,曲名叫standbyme,希望你们能够喜欢,谢谢。standbyme,ohstandbyme,ohstandnowstandbyme,if...

可以吃的“水泥”和“咖啡杯”!杨浦这家高颜值咖啡店“拍了拍”你

在热闹的五角场商圈,聚集着诸多网红咖啡馆。今天就跟着小编来看看拥有浓浓INS风的MSTAND咖啡馆吧~这家名叫MSTAND的咖啡馆因其浓浓的INS风,极具辨识度。整间店以黑白灰为主基调,配上金属质...

陈粒“洄游”巡演帷幕拉开 白衣赤足回溯音乐赤子心

封面新闻记者徐语杨11月9日晚,陈粒“洄游”全国巡回演唱会首场成都站温情开唱。陈粒阔别三年再度开启个人巡回演唱会,以精湛的现场舞台魅力与全新的先锋时尚造型、极具体验感的舞美和视觉创意设计,带来全新专...

把 iPad 变成“iMac”,elago 推出 Magnetic Stand 支架

IT之家11月30日消息,苹果在上月推出打开M2芯片的iPadPro之后,配件厂商elago近日推出了全新的MagneticStand铝合金支架,能够将iPadPro...

Stand Studio 2025春夏系列,现代与经典的融合

StandStudio2025春夏系列,在经典的款式之中,结合了现代的流行元素,让其以崭新的面貌展现出来。让夹克套装、皮革、短裙等款式的服装,在纯色简约大方的气质中,流苏元素的装饰更多了细节潮范儿...

M Stand全国机场首店入驻浦东机场

最近,MStand全国机场首店在浦东机场1号航站楼开业迎客,该品牌店位于浦东机场T1到达公众区4号门附近。MStand此次还专门把社交网络中的热门产品“鲜椰冰咖”带到了浦东机场店。MStand于...

Java Scanner 类

java.util.Scanner是Java5的新特征,我们可以通过Scanner类来获取用户的输入。下面是创建Scanner对象的基本语法:Scanners=newScanner...

扯一把 Spring 的三种注入方式,到底哪种注入方式最佳?

循环依赖这个问题,按理说我们在日常的程序设计中应该避免,其实这个本来也是能够避免的。不过由于种种原因,我们可能还是会遇到一些循环依赖的问题,特别是在面试的过程中,面试考察循环依赖,主要是想考察候选人对...

前端卷Java:我被Shiro的setCipherKey方法坑惨了

哎呀呀,昨晚我被Shiro那个CookieRememberMeManager的setCipherKey方法给坑惨了!明明它要求传入一个byte数组作为加密密钥,但是不告诉我这个数组的长度必须是16、2...

100个Java工具类之58:集合HashSet

HashSet是Java集合框架的一部分。...