恐怕一台服务器要走访另一台服务器里面包车型大巴数据库,举个例子以后有2个数据库服务器

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

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

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

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

方法二:

–创建CrossLibraryTable1脚本:

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

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

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

总结

四. 学习心得

select owner, db_link from dba_db_links;

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% --增长量)
(2) 在提问题时,一定要切中关键点,命中靶心

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

SQL CREATE USER AAA IDENTIFIED BY 1;CREATE USER AAA IDENTIFIED BY 1
*ERROR 位于第 1 行:ORA-00988: 缺少或无效口令

修正代码:

Unsplash

删除:

PS:像上面那样是可以进行查询,然而在项目中使用上面的代码格式就会引发一些问题,那什么问题呢?比如另一个数据库的名称改变了,我们就需要把所有用到这个的地方都得改掉,这样就很麻烦,那么有什么解决方案么,使得改一处就好了?当然有,用数据库同义词就可以轻松搞定!

(2)验证用户是否可以成功登录,并进行访问授权的表
--使用sqlplus登录,并进行查询
sqlplus username/password@localhost:1521/orcl;
select * from scott.test;

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

其中 数据链名称 为添加到本地Oracle数据库控制台(Oracle Enterprise Manager
Console)树节点的服务名要查询对方数据库的表TableName语句如下:SELECT
字段名 FROM TableName@数据链名称;

不同服务器跨库访问实现

二. 问题描述

有两个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中?

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

切换到CrossLibraryTable1下面查询CrossLibraryTable2的数据可以看到报如下错误

下面详细模拟一下整个实验测试的过程:

首先创建数据库链接:

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

执行如下查询语句,其中MEDIADB为database
link名,MEDIADBLINK为先前在tnsnames.ora中定义的连接名,
dbuser为用户名,password为密码

相关文章

You can leave a response, or trackback from your own site.

Leave a Reply

网站地图xml地图