跨Oracle数据库实现表级别的实时同步,Server实现

时间:2020-03-31 03:24来源:江苏十一选五手机版数据库
前言 Unsplash 方法一: 小编们平时会超出八个数据库要会见另一个数据库,可能一台服务器要访问另一台服务器里面包车型客车数据库。那么那些什么得以完毕的呢? 相信看完那篇小说

前言

Unsplash

方法一:

小编们平时会超出八个数据库要会见另一个数据库,可能一台服务器要访问另一台服务器里面包车型客车数据库。 那么那些什么得以完毕的呢? 相信看完那篇小说你就懂了!

一. 前言

这一个难题是上一篇小说《Oracle跨数据库实现准期同步钦点表中的数额》中所提难点的愈发延伸。思索到对数据的实时性必要比较高,设置成准期一并,有一些不妥,须要更正升高校正为实时同步。

上面介绍到的章程,严苛意义上说,并从未贯彻实时同步。是经过Oracle数据库创立同义词+DBlink的艺术,来树立远程映射。在查看数据时,直接去远程查询源库中的表。

而俺平昔关切的是怎样实行同步数量,却从没设想到能够建构映射。此外,还大概有少数正是内需交代,正是一道到对象数据库中的表,不实行增加和删除改操作,只举办询问的操作,那也是能够运用相近词情势解除难题的根本。

这种消除思路的面世,多亏掉在CSDN问答时,热心网民的答疑,下面正是问题详细的情况描述。

在近日多方数据库有布满式查询的急需。上边轻便的介绍如何在oracle中安排达成跨库访问。举例以后有2个数据库服务器,安装了2个数据库。数据库server A和B。未来来落到实处在A库中访谈B的数据库。

如同一口台服务器跨库访问完毕

二. 难题叙述

有三个Oracle数据库,分别摆放在不相同的服务器上,系统均为windows二〇〇三;
这里近年来说成是三个主数据库和从数据库:
(1卡塔尔(قطر‎ 主数据库:oracle_A
(2State of Qatar 从数据库: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中?

第一步、配置A服务器端的tnsnames.ora文件,该公文贮存的任务为:

  1. 第一创立八个数据库CrossLibraryTable1,CrossLibraryTable2
本人本来的管理方式:

因而确立远程连接DBLink+JOB准时职务+存款和储蓄进程的办法,落成了准期同步更新,但无法做到实时同步

$ORACLE_HOME/network/admin/tnsnames.ora

--创建CrossLibraryTable1脚本:

三. 采纳同义词+DB_Link的方式结果步骤

由此能够筛选使用相近词的点子,管理那么些主题材料。首要照旧源于在主题材料陈诉中涉嫌二个点,那正是大家只须求对同步后的表张开查询操作。那点是选拔相近词格局的关键成分。

增添如下行,此中DBLINK为一连名,HOST和PORT为数据库侦听的IP及端口,SETiguanVICE_NAME为数据库的SID,

use master --打开master数据库,一般的创建语句都在master中执行.goif exists (select * from sysdatabases where name='CrossLibraryTable1') drop database CrossLibraryTable1 /*检查有没有这个数据库,如果有就删除它。*/gocreate database CrossLibraryTable1on primary(name='CrossLibraryTable1_data', ------------ 养成好习惯,数据文件加_datafilename='F:代码存放数据库CrossLibraryTable1_data.mdf', ------------ 一定要是.mdf的文件,代表主数据文件size=5mb, --默认数据库大小maxsize=100mb, --最大容量filegrowth=1mb --增长量)log on(name='CrossLibraryTable1_log', ------------ 养成好习惯,日志文件加_logfilename='F:代码存放数据库CrossLibraryTable1_log.ldf', ------------ 一定要是.ldf的文件,代表日志文件size=1mb, --默认数据库大小filegrowth=10% --增长量)
下边详细模拟一下总体实验测量检验的历程:

复制代码 代码如下:MEDIADBLINK = (DESCCRUISERIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 10.0.0.1)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = db) ) )

--创建CrossLibraryTable2脚本:

(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;

第二步、在A服务器的叁个库中确立B的三个数据的DBLINK。语法如下:

use master --打开master数据库,一般的创建语句都在master中执行.goif exists (select * from sysdatabases where name='CrossLibraryTable2') drop database CrossLibraryTable2 /*检查有没有这个数据库,如果有就删除它。*/gocreate database CrossLibraryTable2on primary(name='CrossLibraryTable2_data', ------------ 养成好习惯,数据文件加_datafilename='F:代码存放数据库CrossLibraryTable2_data.mdf', ------------ 一定要是.mdf的文件,代表主数据文件size=5mb, --默认数据库大小maxsize=100mb, --最大容量filegrowth=1mb --增长量)log on(name='CrossLibraryTable2_log', ------------ 养成好习惯,日志文件加_logfilename='F:代码存放数据库CrossLibraryTable2_log.ldf', ------------ 一定要是.ldf的文件,代表日志文件size=1mb, --默认数据库大小filegrowth=10% --增长量)
(2)验证客商是还是不是能够成功登入,并开展拜见授权的表
--使用sqlplus登录,并进行查询
sqlplus username/password@localhost:1521/orcl;
select * from scott.test;

注意:查询表时,必需带上顾客名,表明是哪个顾客下的表。

实施如下查询语句,在那之中MEDIADB为database link名,MEDIADBLINK为先前在tnsnames.ora中定义的连天名, dbuser为客商名,password为密码

然后,实践完脚本后,刷新一下就能够见到刚刚创制的数据库了:

(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;

复制代码 代码如下: -- Create database link create database link MEDIADB connect to dbuser identified by password using 'MEDIADBLINK';

2.接下来在八个数据Curry面分别创立一个CrossTest1和叁个CrossTest2表用于跨库查询

(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类型字段,

  1. 不能用 select * from 连接的表
  2. 不可能将blob类型的字段出以往本子中。

只要这一个blob类型的字段一定要导过来,能够先创建一时表再插入本地表,方法如下.在pl/sql中施行

首先步 建不时表
create global temporary table foo ( X BLOB )
on commit delete rows;
第二步 插入本地球表面
insert into foo select blobcolumn from remoteTable@dl_remote ;

其三步.使用链接的数据库 3.1 查询、删除和插入数据和操作本地的数据库是一致的,只不过表名必要写成“表名@database link名”,如 select * from table_name@MEDIADB ; 3.2 也可认为这么些表创立二个千篇一律词 create synonym aaa for table_name@MEDIADB ; 如下语句的功能和3.第11中学的同样 select * from aaa; 删除同义词的讲话为 drop synonym aaa;

--创建CrossTest1脚本:

四. 学习体会

select * from tabname@dcmdb where 1=1;

 use CrossLibraryTable1 create table CrossTest1( Id int primary key identity, Name nvarchar(20) )
(1卡塔尔(قطر‎ 在提难点时,要具备以下四个关键点:

A.简洁;B.全面;C.系统
那三点,其实也是明儿早上到庭拆书帮线下分享活动,拆书法家拆解分享的七个有个别。现学现卖,直接拿过来结合作者的主题材料实行阐释。

实质上晚上这种问题,笔者利用了三种艺术开展了摸底求助,一种是Wechat语音的秘诀,还也可以有就是发帖的章程。而在语言提问方面,本身却严重的违反了地点的三条,而在发帖提问中,却只顾到了那三点。那也是进行试探作者,现在要多多留意语言表明的二个点。

方法二:

--创建CrossTest2脚本:

(2State of Qatar 在提难点时,必定要切中关键点,命中靶心

陈诉难点时,必须要交代清楚关键点。比如上述这些难题,最初连我本身都未曾留神自身只供给对table_B表进行查询操作,这一点依旧网上朋友在给自己认同细节经过中,谈到到的。没悟出正是其一细节,成了难题解决的关键点。

率先创制数据库链接:

 use CrossLibraryTable2 create table CrossTest2( Id int primary key identity, Name nvarchar(20) )

复制代码 代码如下:CREATE PUBLIC DATABASE LINK 数据链名称 CONNECT TO 登入客户名 IDENTIFIED BY 密码 USING '(DESC奇骏IPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP卡塔尔国(HOST = 对方Oracle服务器的IP地址卡塔尔(قطر‎(PORT = 端口号卡塔尔国卡塔尔国 卡塔尔 (CONNECT_DATA =(SERVICE_NAME = 对方Oracle服务器服务名卡塔尔(قطر‎ 卡塔尔(قطر‎ 卡塔尔国'

表成立好后,我们再增多几条数据进去:

里面 数据链名称 为丰硕到本地Oracle数据库调节台(Oracle Enterprise Manager ConsoleState of Qatar树节点的服务名要查询对方数据库的表TableName语句如下:SELECT 字段名 FROM TableName@数据链名称;

use CrossLibraryTable1 insert into CrossTest1 values('跨库1测试数据1') insert into CrossTest1 values('跨库1测试数据2') use CrossLibraryTable2 insert into CrossTest2 values('跨库2测试数据1') insert into CrossTest2 values('跨库2测试数据2')

复制表数据:

切换来CrossLibraryTable1下边查询CrossLibraryTable2的数据足以见见报如下错误

insert into 表名 ;

校勘代码:

查看DBLINK:

PS:像下面这样是足以开展查询,不过在品种中动用方面包车型大巴代码格式就能够引发部分主题素材,那怎么难题吗?举例另一个数据库的称呼改成了,大家就要求把具备应用那个的地点都得改掉,那样就很辛劳,那么有哪些应用方案么,使得改一处就好了?当然有,用数据库同义词就足以轻易化解!

select owner, db_link from dba_db_links;

创建同义词步骤如下:

删除:

不一样服务器跨库访谈完成

drop database link dblink名称drop public database link dblink名称

当数据库在不相同服务器下面,用地点的艺术就充裕了,那什么样兑现跨过服务器务器访谈呢?非常粗略,看上边↓↓↓

Oracle密码的难题:

好了,SQL Server跨库跨越服务器务器访谈实现就到那了,即使依据步骤一步一步操作的话,相信你也已经贯彻了,下一篇著作就来谈谈分库分表完成。

SQL CREATE USER AAA IDENTIFIED BY 1;CREATE USER AAA IDENTIFIED BY 1 *E本田UR-VRO揽胜极光 坐落于第 1 行:ORA-00988: 缺乏或无效口令

总结

SQL CREATE USER AAA IDENTIFIED BY"1";

如上便是那篇文章的全部内容了,希望本文的从头到尾的经过对大家的求学只怕干活有着一定的参阅学习价值,感谢我们对剧本之家的协理。

客户已开立

编辑:江苏十一选五手机版数据库 本文来源:跨Oracle数据库实现表级别的实时同步,Server实现

关键词: