使用Oracle DBLink进行数据库之间对象的访问操作

Oracle中自带了DBLink功能,它的作用是将多个oracle数据库逻辑上看成一个数据库,也就是说在一个数据库中可以操作另一个数据库中的对象,例如我们新建了一个数据database1,我们需要操作数据库database2中的表,或者我们需要操作远程机器上数据库database3中的表,我们就可以使用dblink这个强大的功能!

1、我们如果要创建全局的DBLink,就是说无论什么角色都可以使用,那么我们需要先确定用户是否有DBLink权限,如果没有则需要使用sysdba角色给用户授权:

查看用户是有有DBLink权限:

  1. select * from user_sys_privs where privilege like upper(‘%DATABASE LINK%’);    
select * from user_sys_privs where privilege like upper('%DATABASE LINK%');  
没有,则使用sysdba授权:

  1. grant create public database link to dbusername;   
grant create public database link to dbusername; 

2、使用语句创建DBLink:

  1. create database link 要创建的dblink名称  
  2. connect to 要连接数据库的用户名 identified by 要连接数据的密码  
  3. using ’(DESCRIPTION =  
  4.     (ADDRESS_LIST =  
  5.       (ADDRESS = (PROTOCOL = TCP)(HOST = 连接数据库主机IP地址)(PORT = 端口号))  
  6.     )  
  7.     (CONNECT_DATA =  
  8.       (SERVICE_NAME = 连接数据库服务名)  
  9.     )  
  10. )’;  
create database link 要创建的dblink名称
connect to 要连接数据库的用户名 identified by 要连接数据的密码
using '(DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 连接数据库主机IP地址)(PORT = 端口号))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = 连接数据库服务名)
    )
)';
如果创建全局 dblink,必须使用 systm 或 sys 用户,在 database 前加 public:

  1. create public database….  
create public database....
例如,在testdb2中创建test_dblink,来操作主机192.168.1.254中testdb1数据库:

  1. create database link tset_dblink  
  2. connect to username identified by password1  
  3. using ’(DESCRIPTION =  
  4.     (ADDRESS_LIST =  
  5.       (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.254)(PORT = 1521))  
  6.     )  
  7.     (CONNECT_DATA =  
  8.       (SERVICE_NAME = testdb1)  
  9.     )  
  10. )’;  
create database link tset_dblink
connect to username identified by password1
using '(DESCRIPTION =
    (ADDRESS_LIST =
      (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.254)(PORT = 1521))
    )
    (CONNECT_DATA =
      (SERVICE_NAME = testdb1)
    )
)';

3、使用DBLink:

查询另一个数据库中的数据,其他修改、删除是一样的使用,都是另一个数据库表名@本数据库创建dblink名称:

  1. select xxx FROM 表名@dblink名称;   
select xxx FROM 表名@dblink名称; 

例如我们在testdb2中使用dblink查看testdb1中tb_user表中的数据:

  1. select * from tb_user@tset_dblink;  
select * from tb_user@tset_dblink;

查看数据中创建的dblink:

  1. select owner,object_name from dba_objects where object_type=‘DATABASE LINK’;  
  2. select * from dba_db_links;  
select owner,object_name from dba_objects where object_type='DATABASE LINK';
select * from dba_db_links;
删除相应的dblink:

  1. drop database link dblink名称;  
drop database link dblink名称;
关闭dblink连接:

  1. alter session close database link ‘dblink_name’  
alter session close database link 'dblink_name'
创建和删除视图:

  1. create or replace view 视图名 as (select 字段 from 用户.表名@dblink1);    
  2. drop view 视图名;    
create or replace view 视图名 as (select 字段 from 用户.表名@dblink1);  
drop view 视图名;  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值