oracle的同步怎么做,oracle数据库同步解决方案

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

1.所谓的物化视图,

成都创新互联专注于伊金霍洛企业网站建设,响应式网站设计,成都商城网站开发。伊金霍洛网站建设公司,为伊金霍洛等地区提供建站服务。全流程定制网站设计,专业设计,全程项目跟踪,成都创新互联专业和态度为您提供的服务

2手工写TRIGER,

3.通过ORACLE的CDC工具可以实现同步或者异步的表的变化。

4。关于你说的表三和表一表二之间同步,俺没有明白。猜测是对表一表二做ETL,然后放到表三中。只对增量进行抽取和转换。如果是这样。通过上面的一二三步之一后。对增量进行抽取和转换。

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

oracle 怎样实现两个表同步数据同步

为方便完成指定数据表的同步操作,可以采用dblink与merge结合的方法完成。

操作环境: 此数据库服务器ip为192.168.196.76,有center与branch两个库,一般需要将center的表数据同步到branch,center为源库,branch为目标库!

两个一样的oracle 数据库怎么实现数据定期同步?

两个一样的oracle ,定期同步,说白了就是主备用数据库数据同步的问题;

如果数据库A和数据库B是建立在两台独立的数据库服务器上,那么采用dblink方式是一种可行的方式,

第一种方式:前提是数据库A和数据库B本地网是24小时互通的同时对数据同步实时性有比较高的要求,那么可以建立DBLINK,在两个库都建触发器,不管当前在哪个库发生数据更新的时候实时同步数据到目标数据库;

第二种方式:如果数据同步的实时性要求不高,则可以通过定制存储过程的方式(给两个库的数据表加时间戳或者更新标志,)定时同步数据;

第三种方式:通过给两个数据库的数据表加更新标志字段,以第一种方式为主以满足实时性的要求,以第二种方式为辅弥补可能存在的触发器执行更新未成功的情况。

以上的方案都是从数据层面所做的处理,对于数据实时同步还是会存在一定的风险,那么双机热备应该说是最好的选择了。

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

datagurd:

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

流复制:

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

高级复制:

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

如何同步oracle数据结构

一、第一套方案

1、用新的建库脚本创建一套新的数据库,结构和类型都是新的;

2、用数据导入工具,将原数据库的数据导入到新的数控里面;

二、第二套方案

1、用新的建库脚本创建一套新的数据库,结构和类型都是新的;

2、用数据库结构同步工具,将老的数据库结构更新同步到新建的数据库上面;

两套方案肯定都可行,主要在工作量和工作效率上面区别太大,导数据需要工具,可以用Sqlserver提供的DTS,有的结构变动大的需要对应字段关系,太麻烦;

所以我想到用数据库结构同步工具来进行,记得以前就用过这个功能,我们可以在网上轻松找到oracle数据库客户端操作工具PLSQL Developer,这个工具除了对数据库进行日常的维护之外,还提供很多使用的功能,同步两个数据库的结构,就是其中一个,操作步骤如下:

1、打开PLSQL Developer进入新创建的数据库;

打开菜单如下图:

点击菜单--工具--比较用户对象,进入如下图:

会列出所以的表,你可选择单独的表或者多个表同时操作,然后点击目标回话,会弹出要同步的数据库连接对象窗口,输入用户名和密码等等,确定后点击右下角的比较按钮,这样会出现如下的比较窗口:

这时,会把不同之处用脚本列出来,只要点击右边的绿色对号,同步即可;

这样,结构一下就都改好了,很方便。

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

一. 前言

这个问题是上一篇文章《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 ;


网站栏目:oracle的同步怎么做,oracle数据库同步解决方案
文章分享:http://myzitong.com/article/hsdcjp.html