streams流复制中如何初始化复制对象

本文介绍如何使用DBMS_APPLY_ADM.SET_SCHEMA_INSTANTIATION_SCN进行Streams流复制中的数据初始化,并展示了具体的PL/SQL代码示例及验证方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

streams流复制中如何初始化复制对象

http://www.eygle.com/archives/2007/11/streams_instantiated_objects.html

在Streams复制中,可以通过exp/imp方式进行数据初始化,也可以通过DBMS_APPLY_ADM来设置。

通常通过DBMS_APPLY_ADM.SET_SCHEMA_INSTANTIATION_SCN来进行SCHEMA级别的设置:

SQL> DECLARE
  2      v_scn NUMBER;
  3  BEGIN
  4      v_scn := DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER();
  5      DBMS_APPLY_ADM.SET_SCHEMA_INSTANTIATION_SCN@test97(
  6      SOURCE_SCHEMA_NAME => 'SCOTT',
  7      source_database_name => 'TEST201',
  8      instantiation_scn => v_scn,
  9      RECURSIVE => true );
10  END;
11  /

PL/SQL procedure successfully completed.


在目标数据库我们可以通过查询dba_apply_instantiated_objects字典表来确认初始化是否成功:

SQL> col source_database for a20
SQL> col source_object_name for a15
SQL> select source_database,source_object_name,instantiation_scn from dba_apply_instantiated_objects;

SOURCE_DATABASE      SOURCE_OBJECT_N INSTANTIATION_SCN
-------------------- --------------- -----------------
TEST201.EYGLE.COM    DEPT                      6141033
TEST201.EYGLE.COM    EMP                       6141033
TEST201.EYGLE.COM    BONUS                     6141033
TEST201.EYGLE.COM    SALGRADE                  6141033


这是最常用的快速有效数据初始化方式。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值