基于Oracle ADG通过dblink创建物化视图同步数据到目标库

基于Oracle ADG通过dblink创建物化视图同步数据到目标库

环境说明:源端环境Oracle ADG一主一备,版本11.2.0.4,目标端版本11.2.0.4,测试通过dblink方式在目标库创建物化视图同步ADG备库的数据。

PROD --> STANDBY -- > TARGET

第一步:在目标端创建dblink访问standby

复制代码
create database link dblink_scims
 connect to scims identified by  "scims" 
  using '(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = 10..0.0.0)(PORT = 1521)))(CONNECT_DATA =(SERVICE_NAME = orcl)))';
 
SELECT * FROM USER_DB_LINKS ;

SELECT * FROM tscim@dblink_scims

第二步:在目标端创建物化视图,失败了,提示tscim表不带实体日志表,即物化视图日志表

第三步:尝试给tscim添加物化视图日志表

复制代码
SQL> CREATE MATERIALIZED VIEW LOG ON scims.TSCIM  WITH ROWID;

实体化视图日志已创建。

SQL>

第四步:再次在目标库创建物化视图,任然失败了,大概意思是不能从ADG备库创建

第五步:创建到ADG主库的dblink

复制代码
create database link dblink_scims_prod    
 connect to scims identified by  "scims" 
  using '(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = 10.0.0.0)(PORT = 1521)))(CONNECT_DATA =(SERVICE_NAME = orcl)))';
  
SELECT * FROM USER_DB_LINKS ;

SELECT * FROM tscim@dblink_scims_prod;

第六步:再次在目标端创建物化视图,成功创建。

第七步:目标端查询验证数据

附:可能存在的风险,物化视图会占用实际的物理空间,如果是比较大的表需要留意存储空间以及对性能的影响。

相关推荐
钟琛......4 分钟前
Java事务失效(面试题)的常见场景
java·数据库·spring
uwvwko7 分钟前
数据结构学习——树的储存结构
数据库·学习·算法·
熙客1 小时前
MongoDB:索引
数据库·mongodb
孟猛20231 小时前
Unix ODBC和Mysql ODBC
数据库
代码or搬砖2 小时前
Spring JDBC配置与讲解
java·数据库·spring
程序视点2 小时前
MySQL数据库操作完全指南:从入门到闭关
数据库·sql·mysql
远方16093 小时前
65-Oracle Undo机制
数据库·oracle
Java知识库3 小时前
MySQL RC隔离级别惊现间隙锁:是bug吗?
数据库·mysql·bug
工藤学编程3 小时前
分库分表下的 ID 冲突问题与雪花算法讲解
数据库·分布式·mysql
码上库利南4 小时前
详解Redis数据库和缓存不一致的情况及解决方案
数据库·redis·缓存