表级数据同步:使用snapshot,database link,实现
2013-04-25 17:10
411 查看
是要将库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天完全刷新一次。
环境准备
源、目标端
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 as2 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天完全刷新一次。
相关文章推荐
- 使用Sqlserver事务发布实现数据同步
- 使用更改跟踪实现数据同步
- oracle中使用触发器实现数据同步
- 使用文件监控对象FileSystemWatcher实现数据同步
- 使用Sqlserver事务发布实现数据同步
- SQL Server - 使用 Merge 语句实现表数据之间的对比同步
- 使用merge 加 dblink 实现内网中的两个数据同步
- Elasticsearch学习总结六 使用Observer实现HBase到Elasticsearch的数据同步
- 使用Sqlserver事务发布实现数据同步
- 使用databus实现oracle和内存数据库redis之间的数据同步
- 使用文件监控对象FileSystemWatcher实现数据同步
- 使用NFS文件系统实现数据同步
- linux系统下使用rsync实现网站数据实时同步备份
- 使用Sqlserver事务发布实现数据同步
- 使用GoldenGate实现MySQL到Oracle的数据实时同步
- [SQL Server] 使用事务发布与订阅实现数据同步
- 使用 Tungsten Replicator4 实现 mysql -- > mongodb 数据同步
- 使用数据绑定实现多窗口间的数据同步
- Oracle 使用物化视图实现表数据同步
- SQL Server-使用Merge语句实现表数据之间的对比同步