金沙澳门官网下载app-金沙澳门官网网址

同一台服务器跨库访问实现,却没有考虑到可以

前言

Unsplash

方法一:

我们经常会遇到一个数据库要访问另一个数据库,或者一台服务器要访问另一台服务器里面的数据库。 那么这个如何实现的呢? 相信看完这篇文章你就懂了!

一. 前言

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

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

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

这种解决思路的出现,多亏了在金沙澳门官网网址 ,CSDN问答时,热心网友的回答,下面就是问题详情描述。

在目前绝大部分数据库有分布式查询的需要。下面简单的介绍如何在oracle中配置实现跨库访问。比如现在有2个数据库服务器,安装了2个数据库。数据库server A和B。现在来实现在A库中访问B的数据库。

同一台服务器跨库访问实现

二. 问题描述

有两个Oracle数据库,分别布置在不同的服务器上,系统均为windows2003;
金沙澳门官网下载app ,这里暂且说成是一个主数据库和从数据库:
(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中?

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

  1. 首先创建两个数据库CrossLibraryTable1,CrossLibraryTable2
我原来的处理方式:

通过建立远程连接DBLink+JOB定时任务+存储过程的方式,实现了定时同步更新,但不能做到实时同步

$ORACLE_HOME/network/admin/tnsnames.ora

--创建CrossLibraryTable1脚本:

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

之所以能够选择采用同义词的方式,处理这个问题。主要还是源于在问题描述中提到一个点,那就是我们只需要对同步后的表进行查询操作。这点是使用同义词方式的重要要素。

添加如下行,其中DBLINK为连接名,HOST和PORT为数据库侦听的IP及端口,SERVICE_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 = (DESCRIPTION = (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';

本文由金沙澳门官网下载app发布于金沙澳门官网,转载请注明出处:同一台服务器跨库访问实现,却没有考虑到可以

您可能还会对下面的文章感兴趣: