一. 前言
这个问题是上一篇文章<
下面介绍到的方式,严格意义上说,并没有实现实时同步.是通过Oracle数据库创建同义词+DBlink的方式,来建立远程映射.在查看数据时,直接去远程查询源库中的表.
而我一直关注的是如何进行同步数据,却没有考虑到可以建立映射.另外,还有一点就是需要交代,就是同步到目标数据库中的表,不进行增删改操作,只进行查询的操作,这也是可以使用同义词方式解决问题的关键.
这种解决思路的出现,多亏了在CSDN问答时,热心网友的回答,下面就是问题详情描述.
二. 问题描述
这里暂且说成是一个主数据库和从数据库:
(1) 主数据库:oracle_A;
在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表的权限;
--授予username用户查看指定的权限
grant select on test to username;
--撤销权限
基本语法同grant,关键字为revoke;
--使用sqlplus登录,并进行查询
select * from scott.test;
注意:查询表时,务必带上用户名,说明是哪个用户下的表.
①. 创建远程连接 db_link
①. 使用sqlplus登录自己的用户
可以看到这与在Oracle_A源数据库中查到的table_A表中的数据一样.
注意事项:
当远程查询的数据库中包含BLOB字段时,会报出如下错误.
当出现这个错误的时候,那是因为跨库连接查询中的表中存在BLOB类型的字段,所以一定要注意,所有表中存在blob类型字段,
不能用 select * from 连接的表
不能将blob类型的字段出现在脚本中.
如果这些blob类型的字段一定要导过来,可以先建立临时表再插入本地表,方法如下.在pl/sql中执行
第一步 建临时表
create global temporary table foo ( X BLOB )
on commit delete rows;
第二步 插入本地表
分布式查询可能一条SQL语句中有不同远程库的表,相关概念lz可以网上查找,使用时注意下面几点.
使用collocated内联视图—也就是sql要对引用不同远程库的表,要组织好,将相同库的表放一起组织成内联视图,这样oracle就很容易知道这个内联视图里的表是在同一远程库作完查询
后再返回给本地库,这样减少了本地库与远程库的交互次数和传输结果集的数量和次数.
了解cbo优化器对分布式查询的处理(cbo也是尽量转为collocated内联视图),它可能是不高效的,这时候得用其他的方法,比如使用HINT,改造SQL,改造分布式查询的方法(远程库用视图)等
使用hint,特别是driving_site hint(如:parallel,use_hash,full等,它能指定执行计划在远程还是本地做),特别是本地小结果集,远程大结果集的时候,总体结果集较小,希望计划在远程驱动,这样远程执行完毕,将结果集传输到本地,这样避免大结果集的传输.
lz还要学会看执行计划,这很重要,有问题再追问.
以上就是土嘎嘎小编为大家整理的oracle如何跨库连接相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!