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

前端之家收集整理的这篇文章主要介绍了Oracle--DBLink 进行数据库之间对象的访问操作前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
Oracle中自带了DBLink功能,它的作用是将多个oracle数据库逻辑上看成一个数据库,也就是说在一个数据库中可以操作另一个数据库中的对象,例如我们新建了一个数据database1,我们需要操作数据库database2中的表,或者我们需要操作远程机器上数据库database3中的表,我们就可以使用dblink这个强大的功能

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

查看用户是有有DBLink权限:

select * from user_sys_privs where privilege like upper('%DATABASE LINK%');  

没有,则使用sysdba授权:
grant create public database link to dbusername; 

2、使用语句创建DBLink:
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:
create public database....
例如,在testdb2中创建test_dblink,来操作主机192.168.1.254中testdb1数据库
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名称

select xxx FROM 表名@dblink名称; 

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

select * from tb_user@tset_dblink;

查看数据中创建的dblink:

select owner,object_name from dba_objects where object_type='DATABASE LINK';
select * from dba_db_links;
删除相应的dblink:
drop database link dblink名称;
关闭dblink连接:
alter session close database link 'dblink_name'


附:

DBlink创建方式2:PL/sql图形配置界面
打开PL/sql图形界面,找到Database links ,选中Database links,单击右键,选中new,按照配置界面一步一步填写内容即可完成创建。

DBlink创建方式3:利用tnsnames.ora文件中配置的主机字符串名,例如
tnsnames.ora文件中配置了一个主机字符串名:

ORCL =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST =127.0.0.1)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = ORCL)
    )
  )

那么创建sql语句如下:
create database link tset_dblink
connect to username identified by password1
using 'ORCL';
'ORCL'对应中tnsnames.ora文件中的'ORCL'。 原文链接:https://www.f2er.com/oracle/211303.html

猜你在找的Oracle相关文章