物化视图全量刷新的简单测试(63天)
时间:2022-05-04
本文章向大家介绍物化视图全量刷新的简单测试(63天),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
关于物化视图的刷新,如果数据的变化比较大采用了全量刷新的时候,会将现有表里的数据都清空然后放入新的数据,整个过程有点类似delete,insert的感觉,但是刷新后表的高水位线还是会保持不变,效果类似于truncate,insert. 对于堆表来说,在重要的一些表上做truncate简直就是灾难,如果一个表访问频繁,做了truncate之后,在插入数据的过程中,如果访问该表,数据都是0条,这就会带来一些高可用性的问题来,如果采用一个事务,使用delete,insert的方式,那高水位线的问题还是得不到解决,可能在高版本中可以使用shrink之类的方式来做,但是还是有一定的影响。 创建一个物化视图,数据量在40万左右。
create materialized view test_mv tablespace pool_data as select *from test;
使用如下的shell脚本在另一个窗口中执行,来查看物化视图中的数据条数。
while true
do
sqlplus -s n1/n1 <<EOF
set timing on
set pages 0
set feedback off
select count(*) from test_mv;
EOF
done
插入数据之后,反复刷新,让刷新的时间基本稳定下来。
SQL> set time on
08:37:52 SQL> exec dbms_mview.refresh('TEST_MV','C');
PL/SQL procedure successfully completed.
Elapsed: 00:00:50.27
插入一条数据,然后采用全量刷新
08:38:50 SQL> insert into test select *from test where rownum<2;
1 row created.
Elapsed: 00:00:00.10
08:39:44 SQL> commit;
Commit complete.
18:20:33 SQL> exec dbms_mview.refresh('TEST_MV','C');
PL/SQL procedure successfully completed.
Elapsed: 00:00:24.62
18:21:12 SQL> exec dbms_mview.refresh('TEST_MV','C');
PL/SQL procedure successfully completed.
Elapsed: 00:00:26.05
时间基本稳定在20多秒的样子,然后开始测试,在另外一个窗口中执行shell脚本,不停的会去查物化视图里的数据,根据oracle的读一致性,基本都会从undo中读取数据
可以看到刷新的时间开始延长,但是数据条数没有任何变化。
18:24:48 SQL> exec dbms_mview.refresh('TEST_MV','C');
PL/SQL procedure successfully completed.
Elapsed: 00:00:37.49
以下是shell脚本执行时的日志,可以看到数据条数没有任何变化,也算是高可用性的一种体现吧,不过在特定的场景中可以考虑一下。
411425
Elapsed: 00:00:03.76
411425
Elapsed: 00:00:01.01
411425
Elapsed: 00:00:01.03
411425
Elapsed: 00:00:01.07
411425
Elapsed: 00:00:01.87
411425
Elapsed: 00:00:00.76
411425
Elapsed: 00:00:03.60
411425
Elapsed: 00:00:03.00
411425
Elapsed: 00:00:04.28
411425
Elapsed: 00:00:05.06
411425
Elapsed: 00:00:08.61
411425
Elapsed: 00:00:02.44
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.03
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.03
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.03
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.03
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.03
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.04
411425
Elapsed: 00:00:00.03
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- C语言俄罗斯方块(旧版本)
- 线性表--顺序表--数组(三)
- 算法复杂度(二)
- 线性表--顺序表--单向链表(四)
- C语言俄罗斯方块(新版本完整代码)
- 线性表--顺序表--双向链表(六)
- C/C++什么时候使用二级指针,你知道吗?
- 萌新学习C++容易漏掉的知识点,看看你中招了没有(一)
- 萌新不看会后悔的C++string字符串常用知识点总结
- salesforce零基础学习(九十六)项目中的零碎知识点小总结(四)
- CodeForces - 260C
- 疯子的算法总结(九) 图论中的矩阵应用 Part 2 矩阵树 基尔霍夫矩阵定理 生成树计数 Matrix-Tree
- STL常用对象,不会搞得C++跟没学一样
- 桥接模式
- CF--思维练习--CodeForces - 220C Little Elephant and Shifts (STL模拟)