oracle 10g 快照操作方法
一不小心听说了oracle 数据库快照,这个词我当初一听就楞了,不知道这个是什么玩意,然后花了点时间研究了下,以下是我通过网络学习的
快照主要是用于分布式数据库,我们有数据库A,A中有个表a,我们在数据库B中要使用数据库A中a表的数据,这时候我们就可以在数据库B中创建数据库A的快照,这样可以提高我们的效率。
我理解快照就是对表的复制,定时的将a表复制到b表(包括数据)
注意用快照创建的表是只读的
创建快照的方法
1、先需要在A数据库中建立表a的快照日志
只有先建立表a的快照日志,才能在快照中执行快速刷新
Create snapshot log on a;
2、在数据库B下建立到数据库A用户的数据库链link
a)只有建立了到A数据库(用户)的数据库链后才能从A数据库(用户)下的表a中获取数据
Create database link link_test
Connect to A数据库用户名(username)identified by A数据库密码(password) using ‘数据库名(database)'
此图为用pl/sql建立link的视图
3、在数据库B下建立a表的快照
Create snapshot t_a——>将来在数据B中对于a表快照显示的表名
REFRESH COMPLETE START WITH SYSDATE+1/246060 NEXT SYSDATE+1/2460
as select from a@link_test
SYSDATE+1/246060表示设定oracle 自动在1秒钟执行刷新,NEXT SYSDATE+1/2460
表示以后每个1分钟自动刷新一次
说明 REFRESH是刷新方法
刷新方式有COMPLETE(完全刷新)和FAST(快速刷新)两种,
而START WITH是说明开始执行的时间。
Next是下次执行的时间
而AS以后是构成快照的查询方法。
刷新方法
快照的刷新有两种方式:快速刷新和完全刷新。快速刷新需要快照的主表先有快照日志存在;完全刷新时oracle执行快照查询,将结果放入快照。快速刷新比完全刷新快,因为快速刷新将主数据库的数据经网络发送到快照的数据少,仅需传送主表中修改过的数据,而完全刷新要传送快照查询的全部结果。
4、修改快照
Alter snapshot t_a refresh fast
Start with sysdate+1/2880 next sysdate+1
此sql语句意思设定oracle 自动在30秒(30/246060)后进行第一次快速刷新,以后,每隔1天快速刷新一次
5、查看快照刷新的日期
SELECT NAME,LAST_REFRESH
FROM ALL_SNAPSHOT_REFRESH_TIMES
6、手动刷新快照在命令界面执行
EXEC DBMS_SNAPSHOT.REFRESH('t_a ','C');
第一个参数是要刷新的快照名
第二个参数是刷新的方式,F----FAST, C---COMPLETE
7、说明
a) 建立快照日志时oracle数据库为我们建立了一个基于a的触发器(我没有找到)
tlog$_a和快照日志表mlog$_a(这个已经找到);
网上朋友说在建立快照时建立了一些表,视图之类的,我只找到了表,其他的没有找到,希望得到大家的帮助。
的如果有什么问题请大家多多指出,共同进步。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程