Unsplash

一. 前言

这个问题是上一篇文章《Oracle跨数据库实现定时同步指定表中的数据》中所提问题的进一步延伸。考虑到对数据的实时性要求比较高,设置成定时同步,有点不妥,需要改善升级更改为实时同步。

下面介绍到的方式,严格意义上说,并没有实现实时同步。是通过Oracle数据库创建同义词+DBlink的方式,来建立远程映射。在查看数据时,直接去远程查询源库中的表。

而我一直关注的是如何进行同步数据,却没有考虑到可以建立映射。另外,还有一点就是需要交代,就是同步到目标数据库中的表,不进行增删改操作,只进行查询的操作,这也是可以使用同义词方式解决问题的关键。

这种解决思路的出现,多亏了在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只有查询功能的用户

<1> 创建用户

sqlplus /nolog

conn /as sysdba;

create user username identified by password;

<2> 查看所有的用户列表

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

select * from all_users;

<3>授予权限

为了能够保证能够登陆,必须赋予如下权限

--授予username用户创建session的权限,即登陆权限

grant create session to username;

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

grant unlimited tablespace to username;

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

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

sqlplus scott/tiget@localhost:1521/orcl

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

grant select on test to username;

--撤销权限

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

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

--使用sqlplus登录,并进行查询

sqlplus username/password@localhost:1521/orcl;

select * from scott.test;

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

(3)创建远程连接DB_Link

<1> 创建远程连接 db_link

create public database link db32 connect to tianzhi_test identified by "tianzhi_test" using '192.168.56.6:1521/ORCL'

<2> 测试远程连接是否成功

select * from tianzhi_smart.zh_item_news@db32;

(4)在Oracle_B端创建同义词

<1> 使用sqlplus登录自己的用户

sqlplus tianzhi_smart/tianzhi_smart@localhost:1521/orcl

<2> 创建同义词

create or replace public synonym TEST1130 for scott.TEST@db32;

<3> 查询测试

select * from TEST1130;

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

注意事项:

当远程查询的数据库中包含BLOB字段时,会报出如下错误.

**ORA-22992: 无法使用从远程表选择的 LOB 定位器 **

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

不能用 select * from 连接的表

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

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

第一步 建临时表

create global temporary table foo ( X BLOB )

on commit delete rows;

第二步 插入本地表

insert into foo select blobcolumn from remoteTable@dl_remote ;

四. 学习心得

(1) 在提问题时,要具有以下三个关键点:

A.简洁;B.全面;C.系统

这三点,其实也是今晚参加拆书帮线下分享活动,拆书家拆解分享的一个片段。现学现卖,直接拿过来结合我的问题进行阐述。

其实上午这种问题,我采用了两种方式进行了询问求助,一种是微信语音的方式,还有就是发帖的方式。而在语言提问方面,自己却严重的违反了上面的三条,而在发帖提问中,却注意到了这三点。这也是提醒我,以后要多多注意语言表达的一个点。

(2) 在提问题时,一定要切中关键点,命中靶心

描述问题时,一定要交代清楚关键点。比如上述这个问题,最初连我自己都没有在意我只需要对table_B表进行查询操作,这点还是网友在给我确认细节过程中,提及到的。没想到就是这个细节,成了问题解决的关键点。

oracle 表 实时同步,跨Oracle数据库实现表级别的实时同步相关推荐

  1. oracle数据泵到处表结构,数据泵导出数据库所有表结构

    Oracle11g中数据的倒库和入库操作以及高版本数据导入低版本数据可能引发的问题 文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaov ...

  2. hive查勘表结构_Hive中的数据库、表、数据与HDFS的对应关系

    1.hive数据库 我们在hive终端,查看数据库信息,可以看出hive有一个默认的数据库default,而且我们还知道hive数据库对应的是hdfs上面的一个目录,那么默认的数据库default到底 ...

  3. mysql全表重命名备份_Mysql数据库和表的常用操作以及数据备份恢复

    数据库 查看所有数据库 show databases; 使用数据库 use 数据库名; 查看当前使用的数据库 select database(); 创建数据库 create database 数据库名 ...

  4. mysql 表引擎 entity framework_EntityFramework之数据库以及表基本创建(一)

    前言 之前有学过EF一段时间那时EF才4.0似乎还不太稳定,而现在EF都已7.0版本,同时AspNet Identity都与此大有关联,看来是大势所趋于是开始学习EF,在学EF过程中也遇到一些小问题, ...

  5. mysql 查看所有表的引擎_MySQL查看数据库、表的占用空间大小以及某个库中所有表的引擎类型...

    本文章来给大家介绍一些常用的MySQL查看数据库.表的占用空间大小sql命令吧,希望此教程 对各位同学会有所帮助. 查看各库的大小代码如下复制代码 SELECT SUM(DATA_LENGTH)+SU ...

  6. 用户数据表设计借鉴 浅谈数据库用户表结构设计,第三方登录 基于 Token 的身份验证

    最近对用户数据表的设计比较感兴趣,看到了两篇比较好的文章. 浅谈数据库用户表结构设计,第三方登录 转载于: https://www.cnblogs.com/jiqing9006/p/5937733.h ...

  7. php判断mysql表的字段_tp6 获取数据库某个表的所有字段名称_php菜鸟技术天地-CSDN博客...

    $rs = Db::query("show tables"); PHP获取mysql数据表的字段名称和详细信息的一些列命令 SHOW DATABASES //列出 MySQL Se ...

  8. mysql清空数据库中所有表数据_清空mysql数据库所有表数据

    1,查看数据库状态 及启动停止 /etc/init.d/mysqld status/etc/init.d/mysqld start/etc/init.d/mysqld stop 2,给用户配置初始密码 ...

  9. sqoop动态分区导入mysql,sqoop 导入数据到hive分区表(外表,内表) 指定分区 指定数据库 指定表...

    sqoop 导入数据到hive 1.1.导入数据到hive分区表(内表),指定分区 创建hive分区表 –hive-database 指定数据库 –table 指定表 –hive-overwrite ...

最新文章

  1. jquery.ajax
  2. PAT-A Maximum Subsequence Sum
  3. python10086查询系统_Python获取移动性能指标
  4. Linux中Redis的卸载
  5. 一头盔一电极,MIT机器人读心完毕
  6. 白日门手游luac文件加密怎么解密_浅析android手游lua脚本的加密与解密
  7. 【java学习】面向对象编程(一)【详解篇13】
  8. 【学习笔记】大数据可视化简介
  9. 北京内推 | 微软亚洲研究院自然语言计算组招聘NLP研究实习生
  10. 祝新年快乐html小程序,小程序网页开发真诚的祝福大家2018...
  11. Kafka——创建无消费者组的消费者消费订阅主题
  12. 碉堡的GitHub使用方式
  13. 数学计算机小论文范文,数学小论文 数学小论文范文5篇
  14. 诚邀校友企业参加香港科大研究生线上宣讲及招聘会
  15. 浏览器的重排与重绘是什么意思?
  16. 法约尔的五大管理职能
  17. linux移动数据,基于嵌入式Linux移动数据同步研究与实现
  18. 服务器控制大屏显示,显示大屏唯瑞(Vewell)显示屏多种尺寸可定制,可交互式电子显示屏VewellV82-T17BL3...
  19. Qt5入门学习——模型/视图结构
  20. C++ 对16进制字符串进行偶校验

热门文章

  1. 【超详细Django网站开发过程9】便利店管理系统之——管理员登录、注销功能
  2. Word的多级列表及自定义带级联编号有序列表的方法
  3. 来自卡内基梅隆计算机科学系主任的回复
  4. t6修改服务器ip,用友t6服务器更换ip地址
  5. 重装win10时,出现“在EFI系统上,windows只能安装到GPT磁盘”解决方法
  6. T检验与F检验的区别和关系
  7. PHP动态创建Web站点
  8. Android的CTS测试
  9. PL/SQL 记录与集合
  10. 如何在 Mac 或 Windows 上将 PDF 转换为 Word 而不丢失格式