GaussDB新特性物化视图介绍

物化 视图介绍

物化视图是相对普通视图而言的。普通视图是虚拟表,而物化视图实际上就是存储SQL执行语句的结果,可以直接使用数据而不用重复执行查询语句,起到缓存的效果。

按照刷新方式物化视图分为全量物化视图和增量物化视图两种:

全量物化视图:仅支持对已创建的物化视图进行全量更新,而不支持进行增量更新。创建全量物化视图语法和CREATE TABLE AS语法类似。

增量物化视图:可以对物化视图增量刷新,需要用户手动执行语句完成对物化视图在一段时间内的增量数据刷新。与全量创建物化视图的不同在于目前增量物化视图所支持场景较小。目前物化视图创建语句仅支持基表扫描语句或者UNION ALL语句。

GaussDB即支持全量物化视图也支持增量物化视图,目前Ustore引擎不支持创建、使用物化视图,物化视图是现代数据库的高级特性。目前GaussDB已经全面支持物化视图功能,有了物化视图功能,GaussDB在数据库兼容性方面又迈出了一大步,下面将介绍GaussDB全量和增量物化视图的使用。

GaussDB全量 物化视图

2 .1 全量物化视图语法格式:

创建全量物化视图CREATE MATERIALIZED VIEW [ view_name ] AS query;

刷新全量物化视图REFRESH MATERIALIZED VIEW [ view_name ];

删除物化视图DROP MATERIALIZED VIEW [ view_name ];

查询物化视图SELECT * FROM [ view_name ];

参数说明:

view_name:要创建的物化视图的名称。

AS query:一个SELECT、TABLE 或者VALUES命令。

2 .2 全量物化视图示例:

--创建表和插入数据。

openGauss=# CREATE TABLE t_full(c1 int, c2 int);

openGauss=# INSERT INTO t_full VALUES(1, 1);

openGauss=# INSERT INTO t_full VALUES(2, 2);

--创建全量物化视图。

openGauss=# CREATE MATERIALIZED VIEW mv AS select count(*) from t_full;

CREATE MATERIALIZED VIEW

--查询物化视图结果。

openGauss=# SELECT * FROM mv;

count


2

(1 row)

--向物化视图中基表插入数据。

openGauss=# INSERT INTO t_full VALUES(3, 3);

INSERT 0 1

--对全量物化视图做全量刷新。

openGauss=# REFRESH MATERIALIZED VIEW mv;

REFRESH MATERIALIZED VIEW

--查询物化视图结果。

openGauss=# SELECT * FROM mv;

count


3

(1 row)

--删除物化视图。

openGauss=# DROP MATERIALIZED VIEW mv;

DROP MATERIALIZED VIEW

GaussDB增量物化视图

3 .1 增量物化视图语法格式:

创建增量物化视图CREATE INCREMENTAL MATERIALIZED VIEW [ view_name ] AS query;

全量刷新物化视图REFRESH MATERIALIZED VIEW [ view_name ];

增量刷新物化视图REFRESH INCREMENTAL MATERIALIZED VIEW [ view_name ];

删除物化视图DROP MATERIALIZED VIEW [ view_name ];

查询物化视图SELECT * FROM [ view_name ];

view_name:要创建的物化视图的名称。

AS query:一个SELECT、TABLE 或者VALUES命令。

3.2 增量物化视图示例:

--创建表和插入数据。

openGauss=# CREATE TABLE t_v(c1 int, c2 int);

openGauss=# INSERT INTO t_v VALUES(1, 1);

openGauss=# INSERT INTO t_v VALUES(2, 2);

--创建增量物化视图。

openGauss=# CREATE INCREMENTAL MATERIALIZED VIEW mv AS SELECT * FROM t_v;

CREATE MATERIALIZED VIEW

--再次插入数据。

openGauss=# INSERT INTO t_v VALUES(3, 3);

INSERT 0 1

--增量刷新物化视图。

openGauss=# REFRESH INCREMENTAL MATERIALIZED VIEW mv;

REFRESH MATERIALIZED VIEW

--查询物化视图结果。

openGauss=# SELECT * FROM mv;

c1 | c2

----+----

1 | 1

2 | 2

3 | 3

(3 rows)

--再次插入数据。

openGauss=# INSERT INTO t_v VALUES(4, 4);

INSERT 0 1

--全量刷新物化视图。

openGauss=# REFRESH MATERIALIZED VIEW mv;

REFRESH MATERIALIZED VIEW

--查询物化视图结果。

openGauss=# select * from mv;

c1 | c2

----+----

1 | 1

2 | 2

3 | 3

4 | 4

(4 rows)

--删除物化视图。

openGauss=# DROP MATERIALIZED VIEW mv;

DROP MATERIALIZED VIEW

GaussDB物化视图使用支持和限制场景

4 .1 物化视图支持的场景

1)单表查询语句。

2)多个单表查询的UNION ALL。

3)物化视图上支持创建索引。

4)物化视图支持Analyze操作。

4.2 物化视图不支持的场景

1)物化视图中不支持多表Join连接计划以及subquery计划。

2)除少部分ALTER操作外,不支持对物化视图中基表执行绝大多数DDL操作。

3)物化视图不支持增删改操作,只支持查询语句。

4)不支持用临时表/hashbucket/unlog/分区表创建物化视图。

5)不支持物化视图嵌套创建(即物化视图上创建物化视图)。

6)仅支持行存表,不支持列存表。

7)不支持UNLOGGED类型的物化视图,不支持WITH语法。

相关推荐
2301_800256111 小时前
8.2 空间查询基本组件 核心知识点总结
数据库·人工智能·算法
吃喝不愁霸王餐APP开发者1 小时前
霸王餐API文档自动化:Spring REST Docs与Asciidoctor多模块聚合
数据库·spring·自动化
默恋~微凉1 小时前
Mysql 备份与还原
数据库·mysql
研华科技Advantech2 小时前
储能AI化的数据瓶颈与破解路径:研华全栈方案实践分析
数据库·人工智能·储能·智能体
大锦终2 小时前
【MySQL】索引
数据库·mysql
jnrjian2 小时前
Hash index initrans 的修改及 partition的增
数据库·oracle
一 乐2 小时前
美食推荐|基于springboot+vue的美食分享系统设计与实现(源码+数据库+文档)
前端·数据库·vue.js·spring boot·后端·美食
星环处相逢2 小时前
MySQL MHA 全解析与实战部署指南
数据库·mysql
一只专注api接口开发的技术猿2 小时前
构建电商数据中台:基于淘宝 API 关键词搜索接口的设计与实现
大数据·开发语言·数据库
未来之窗软件服务3 小时前
服务器运维(十八)国产化数据库服务漏洞安全——东方仙盟炼气期
运维·服务器·数据库·服务器运维