达梦数据库物化视图基本使用

物化视图 (MATERIALIZED VIEW) 是从一个或几个基表导出的表,是目标表在特定时间点上的一个副本,占用存储空间,同视图相比,它存储了导出表的真实数据。物化视图可以用于数据复制(Data Replication),也可用于数据仓库缓存结果集以此来提升复杂查询的性能。

当所依赖的一个或多个基表的数据发生更新,必须启用刷新机制才能保证数据是最新的。本章介绍物化视图的刷新模式、刷新时机、刷新选项及刷新方式。

环境说明:

数据库:DM8

相关关键字:物化视图

一、刷新模式

物化视图刷新模式分为:FAST、COMPLETE、FORCE。

  • FAST:根据相关表上的数据更改记录进行增量刷新。普通 DML 操作生成的记录存在于物化视图日志。使用 FAST 刷新之前,必须先建好物化视图日志。

  • COMPLETE:通过执行物化视图的定义脚本进行完全刷新。

  • FORCE:默认选项。当快速刷新可用时采用快速刷新,否则采用完全刷新。

二、刷新时机

物化视图刷新时机分为:ON COMMIT、START WITH … NEXT、ON DEMAND、NEVER REFRESH。

  • ON COMMIT:在相关表上视图提交时进行快速刷新。刷新是由异步线程执行的,因此COMMIT 执行结束后可能需要等待一段时间物化视图数据才是最新的。

  • START WITH … NEXT :START WITH 用于指定首次刷新物化视图的时间,NEXT 指定自动刷新的间隔。

  • ON DEMAND:由用户通过 REFRESH 语法进行手动刷新。如果指定了 START WITH 和 NEXT子句就没有必要指定 ON DEMAND。l

  • NEVER REFRESH:物化视图从不进行刷新。

三、刷新选项

物化视图刷新选项分为:WITH PRIMARY KEY和WITH ROWID。

  • WITH PRIMARY KEY :默认选项。只能基于单表;必须含有 PRIMARY KEY 约束,不能含有对象类型 。

  • WITH ROWID:只能基于单表;不能含有对象类型;如果使用 WITH ROWID 的同时使用快速刷新,则必须将 ROWID 提取 出来,和其他列名一起,以别名的形式显示。

四、创建物化视图

4.1 创建手动刷新的物化视图

4.1.1 创建表T1

SQL> CREATE TABLE T1(ID INT , PRICE DEC,PRIMARY KEY (ID));
SQL> INSERT INTO T1 SELECT LEVEL, DBMS_RANDOM.VALUE(0,100) FROM DUAL CONNECT BY LEVEL<=100;
SQL> COMMIT;

4.1.2 创建物化视图MV_T1

SQL> CREATE MATERIALIZED VIEW MV_T1 AS SELECT * FROM T1;

4.1.3 更新表的数据

SQL> UPDATE T1 SET PRICE=100 WHERE ID=8;
SQL> COMMIT;

4.1.4 数据比对

查看表T1的数据

查看物化视图MV_T1的数据

物化视图中的数据没有同步更新,现在手动刷新物化视图并查看结果

手动刷新物化视图:

SQL> REFRESH MATERIALIZED VIEW MV_T1;

查看手动刷新后的物化视图:

4.2 创建自动刷新的物化视图

4.2.1 创建表T2

SQL> CREATE TABLE T2(ID INT  , PRICE DEC,PRIMARY KEY (ID));
SQL> INSERT INTO T2  SELECT LEVEL, DBMS_RANDOM.VALUE(0,100) FROM DUAL CONNECT BY LEVEL<=100;
SQL> COMMIT;

4.2.2 创建物化视图MV_T2

创建自动刷新的物化视图,需要创建物化视图日志;

SQL> CREATE MATERIALIZED VIEW LOG ON T2;
SQL> CREATE MATERIALIZED VIEW MV_T2 REFRESH COMPLETE ON COMMIT AS SELECT * FROM T2;

4.2.3 更新表的数据

SQL> UPDATE T2 SET PRICE=80 WHERE ID=6;
SQL> COMMIT;

4.2.4 数据比对

查看表T2的数据

查看物化视图MV_T2的数据

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
第 1 章 结构化查询语言 DM_SQL 简介 12 1.1 DM_SQL 语言的特点 12 1.2 保留字与标识符 13 1.3 DM_SQL 语言的功能及语句 13 1.4 DM_SQL 所支持的数据类型 14 1.4.1 常规数据类型 14 1.4.2 位串数据类型 16 1.4.3 日期时间数据类型 17 1.4.4 多媒体数据类型 21 1.5 DM_SQL 语言支持的表达式 21 1.5.1 数值表达式 21 1.5.2 字符串表达式 23 1.5.3 时间值表达式 23 1.5.4 时间间隔值表达式 25 1.5.5 运算符的优先级 26 1.6 DM_SQL 语言支持的数据库模式 27 第 2 章 手册中的示例说明 28 2.1 示例库说明 28 2.2 参考脚本 36 2.2.1 创建示例库 36 2.2.2 创建模式及表 36 2.2.3 插入数据 43 第 3 章 数据定义语句 60 3.1 数据库修改语句 60 3.2 管理用户 63 3.2.1 用户定义语句 63 3.2.2 修改用户语句 68 3.2.3 用户删除语句 70 3.3 管理模式 71 3.3.1 模式定义语句 71 3.3.2 设置当前模式语句 73 3.3.3 模式删除语句 73 3.4 管理表空间 74 3.4.1 表空间定义语句 74 3.4.2 修改表空间语句 75 目录 3.4.3 表空间删除语句 77 3.4.4 表空间失效文件检查 77 3.4.5 表空间失效文件恢复准备 78 3.4.6 表空间失效文件恢复 78 3.5 管理 HTS 表空间 78 3.5.1 创建 HTS 表空间 79 3.5.2 删除 HTS 表空间 79 3.6 管理表 80 3.6.1 基表定义语句 80 3.6.2 基表修改语句 110 3.6.3 基 表删除语句 120 3.6.4 基表数据删除语句 121 3.7 管理索引 122 3.7.1 索引定义语句 122 3.7.2 索引修改语句 126 3.7.3 索引删除语句 128 3.8 管理位图连接索引 128 3.8.1 位图连接索引定义语句 128 3.8.2 位图连接索引删除语句 130 3.9 管理全文索引 130 3.9.1 全文索引定义语句 130 3.9.2 全文索引修改语句 132 3.9.3 全文索引删除语句 132 3.10 管理序列 133 3.10.1 序列定义语句 133 3.10.2 序列删除语句 136 3.11 管理 SQL 域 136 3.11.1 创建 DOMAIN 136 3.11.2 使用 DOMAIN 137 3.11.3 删除 DOMAIN 137 3.12 管理上下文 138 3.12.1 创建上下文 138 3.12.2 删除上下文 140 3.13 约束的启用与禁用 141 3.14 设置当前会话时区信息 141 3.15 注释语句 142 3.16 设置会话级别的 INI 参数 143 3.17 设置系统级别的 INI 参数 144 3.18 设置列生成统计信息 144 第 4 章 数据查询语句 146 4.1 单表查询 156 4.1.1 简单查询 156 4.1.2 带条件查询 158 目录 4.1.3 集函数 161 4.1.4 分析函数 165 4.1.5 情况表达式 180 4.2 连接查询 183 4.2.1 交叉连接 183 4.2.2 自然连接(NATURAL JOIN) 184 4.2.3 JOIN … USING 185 4.2.4 JOIN…ON 185 4.2.5 自连接 185 4.2.6 内连接(INNER JOIN) 186 4.2.7 外连接(OUTER JOIN) 187 4.2.8 哈希连接(HASH JOIN) 191 4.3 子查询 192 4.3.1 标量子查询 192 4.3.2 表子查询 193 4.3.3 派生表子查询 196 4.3.4 定量比较 196 4.3.5 带 EXISTS 谓词的子查询 197 4.3.6 多列表子查询 198 4.4 公用表表达式 199 4.4.1 公用表表达式的作用 201 4.4.2 公用表表达式的使用 201 4.5 合并查询结果 202 4.6 GROUP BY 和 HAVING 子句 204 4.6.1 GROUP BY 子句的使用 204 4.6.2 ROLLUP 的使用 205 4.6.3 CUBE 的使用 206 4

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

保定公民

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值