oracle向其他表同步数据,跨Oracle数据库实现表级别的实时同步

本文探讨了如何在Windows 2003环境下,通过创建远程DBLink和使用同义词,实现Oracle数据库A(table_A)的变更实时同步到从数据库B(table_B)。重点介绍了权限设置、DBLink的创建、同义词的使用以及处理BLOB字段的方法,以确保仅进行查询操作的同时保持数据同步的高效性。
摘要由CSDN通过智能技术生成

有两个Oracle数据库,分别布置在不同的服务器上,系统均为windows2003;

这里暂且说成是一个主数据库和从数据库:

(1) 主数据库: oracle_A ;

(2) 从数据库: oracle_B ;

在oracle_A中有一个表table_A与oracle_B中的表table_B 结构相同 ;

我是处在oracle_B,oracle_A数据库分配给我有一个访问oracle_A表table_A的用户,该用户 只拥有查询的权限 ;

另外,需要 说明的一点 ,就是在oracle_B处,只需对table_B表进行查询的操作,不进行其他增删改的操作。

场景介绍完了, 我的问题 的是,如何在oracle_A中表table_A发生变化时,实时更新同步到oracle_B的table_B中?

我原来的处理方式:

通过建立远程连接DBLink+JOB定时任务+存储过程的方式,实现了定时同步 更新,但不能做到实时同步 。

二:采用同义词+DB_Link的方式结果步骤

之所以能够选择采用同义词的方式,处理这个问题。主要还是源于在问题描述中提到一个点,那就是我们只需要对同步后的表进行 查询 操作。这点是使用同义词方式的重要要素。

下面详细模拟一下整个实验测试的过程:

(1)首先在Oracle_A端创建一个对table_A只有查询功能的用户创建用户

sqlplus /nolog

conn /as sysdba;

create user username identified by password;

查看所有的用户列表

用户创建完成后,查看用户是否创建成功

select * from all_users;

授予权限

为了能够保证能够登陆,必须赋予如下权限授予username用户创建session的权限,即登陆权限

grant create session to username;

授予username用户使用表空间的权限

grant unlimited tablespace to username;

oracle对权限管理比较严谨,普通用户之间也是默认不能互相访问的,需要互相授权.

如果scott用户要授权给username用户查看自己的test表的权限;

sqlplus [email protected]:1521/orcl

授予username用户查看指定的权限

grant select on test to username;

撤销权限

基本语法同grant,关键字为revoke;

(2)验证用户是否可以成功登录,并进行访问授权的表

使用sqlplus登录,并进行查询sqlplus [email protected]:1521/orcl;

select * from scott.test;

注意:查询表时,务必带上用户名,说明是哪个用户下的表。

(3)创建远程连接DB_Link创建远程连接 db_link1create public database link db32 connect to tianzhi_test identified by "tianzhi_test" using '192.168.56.6:1521/ORCL'

测试远程连接是否成功

(4)在Oracle_B端创建同义词使用sqlplus登录自己的用户1sqlplus [email protected]:1521/orcl

创建同义词1create or replace public synonym TEST1130 for [email protected];

3.查询测试1select * from TEST1130;

可以看到这与在Oracle_A源数据库中查到的table_A表中的数据一样.

注意事项:

当远程查询的数据库中包含BLOB字段时,会报出如下错误.1ORA-22992: 无法使用从远程表选择的 LOB 定位器

当出现这个错误的时候,那是因为跨库连接查询中的表中存在BLOB类型的字段,所以一定要注意,所有表中存在blob类型字段,

不能用 select * from 连接的表

不能将blob类型的字段出现在脚本中。

如果这些blob类型的字段一定要导过来,可以先建立临时表再插入本地表,方法如下.在pl/sql中执行

第一步 建临时表1

2create global temporary table foo ( X BLOB )

on commit delete rows;

第二步 插入本地表1insert into foo select blobcolumn from [email protected]_remote ;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值