我是靠谱客的博主 无聊秀发,最近开发中收集的这篇文章主要介绍表级数据同步:使用snapshot,database link,实现,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

是要将库1(源端)中的表replica_test1的数据同步到库2(目标端),用到了dblink,snapshot,snapshot log等技术。

环境准备

 

源、目标端
SQL> create user dbrep identified by dbrep;
SQL> grant connect,resource to dbrep;
SQL> grant create database link to dbrep;
SQL> grant create snapshot to dbrep;
目标库
建立好网络连接,并创建dblink
conn dbrep/dbrep
SQL> create database link source_rep
    connect to dbrep identified by dbrep
    using 'DWH01';
源端:
conn dbrep/dbrep
create table replica_test1(
id number(10) primary key,
name varchar2(50),
job varchar2(50))
;


创建快照日志


SQL> create snapshot log on replica_test1;

目标端:


--创建快照


SQL> create snapshot replica_test1 as
  2  select * from replica_test1@source_rep;
这儿的replica_test1是以物化视图的形式存在。

--刷新方式:设置了1分钟快速刷新
SQL>  alter snapshot replica_test1 refresh fast start with sysdate+1/1440 next sysdate+1/1440  
with primary key;

测试:


在源端
SQL> insert into replica_test1 values(1,'tan','dba');
SQL> commit;

目标端 :
SQL> select * from replica_test1;
一分钟后在目标库查看,出现相应的结果。


快照的刷新有两种方式:快速刷新和完全刷新
快速刷新需要快照的主表先有快照日志存在;
完全刷新时oracle执行快照查询,将结果放入快照。
刷新方式定义和物化视图的一样,不同的是中间有网络,完全刷新网络时间的影响更明显。

  Alter snapshot replica_test1 refresh fast Start with sysdate+1/1440 next sysdate+1/144;
  --此SQL语句的意思为:设定oracle自动在1分钟

  Alter snapshot replica_test1 refresh complete Start with sysdate+1/2880 next sysdate+1;
  --设定oracle自动在30钞,以后每隔1天完全刷新一次。

 

最后

以上就是无聊秀发为你收集整理的表级数据同步:使用snapshot,database link,实现的全部内容,希望文章能够帮你解决表级数据同步:使用snapshot,database link,实现所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(50)

评论列表共有 0 条评论

立即
投稿
返回
顶部