• 售前

  • 售后

热门帖子
入门百科

oracle 10g 快照操作方法

[复制链接]
123456819 显示全部楼层 发表于 2021-10-26 13:06:48 |阅读模式 打印 上一主题 下一主题
一不警惕听说了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/24*60*60 NEXT SYSDATE+1/24*60
   as select * from a@link_test
SYSDATE+1/24*60*60:表示设定oracle 主动在1秒钟实行刷新,NEXT SYSDATE+1/24*60
表示以后每个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/24*60*60)后进行第一次快速刷新,以后,每隔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(这个已经找到);
网上朋友说在创建快照时创建了一些表,视图之类的,但是我只找到了表,其他的没有找到,希望得到大家的资助。
总结的假如有什么题目请大家多多指出,共同进步。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作