网站首页 > 文章中心 > 其它

oracle怎么互相同步

作者:小编 更新时间:2023-09-28 08:32:59 浏览量:62人看过

如何实现Oracle数据库之间的数据同步

①所谓的物化视图,

ETL是个比较复杂也好玩的东西.多种方式可以实现,但是相互影响较大.容易顾此失彼.比如说管理和性能的平衡问题就是其中之一.

如何跨Oracle数据库实现表级别的实时同步

一. 前言

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

下面介绍到的方式,严格意义上说,并没有实现实时同步.是通过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;

第二步 插入本地表

Oracle不同数据库之间同步处理方案

背景:项目中遇到的问题,需要二区两台数据库之间同步一些表,以及导出sql文件同步至三区数据库.

新建SQL文件生成的目录D:mptmsudataDNLTBDIR.

二区数据库中执行下列语句:

①.)新建二区数据库服务器到二区数据库服务器的数据库DATABASE LINK文件.

通过Windows系统自带的计划任务执行下面批处理实现数据入库

①.)三区区数据库服务器新建表DNL_SQLJL.

三区数据库中执行下列语句:

两个oracle数据库之间的数据同步

datagurd:

主要备库的方式,就是数据库对数据库的备份方式,主要是解决容灾的.

流复制:

主要是利用oracle的归档日志,进行增量备份来实现的,不仅可以配置只复制某些表,还可以配置仅复制某些表上的ddl或dml.可以复制到表,用户,数据库级别.

高级复制:

主要是基于触发器的原理来触发数据同步的,所以呢,高级复制无法实现用户,数据库级别的对象复制,只能做些表、索引和存储过程的复制.

以上就是土嘎嘎小编为大家整理的oracle怎么互相同步相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!

版权声明:倡导尊重与保护知识产权。未经许可,任何人不得复制、转载、或以其他方式使用本站《原创》内容,违者将追究其法律责任。本站文章内容,部分图片来源于网络,如有侵权,请联系我们修改或者删除处理。

编辑推荐

热门文章