您的位置:首页 > 数据库 > Oracle

oracle 创建dblink访问远程数据库

2016-06-15 10:29 295 查看
查找资料,按照下面步骤配置后,发现还是无法远程连接数据库。可能是我对资料没理解透彻,后来发现另一种方法解决了这个问题。

第一种方法(没有成功):

1)在本地数据库tnsnames.ora文件中配置要访问的目标数据库信息.可以直接修改tnsnames.ora文件,或者使用客户端向导界面配置。

一般将下面的HOST和SERVICE_NAME改为要访问的目标数据库信息就可以了。

test_link2
=

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.123)(PORT = 1521))

)

(CONNECT_DATA =

(SERVER = DEDICATED)

(SERVICE_NAME = mai)

)

)

2)执行下面sql:

create [public] database link test_link1

connect to scott identified by tiger using 'test_link2';

其中第一个test_link1是将要创建的dblink的名字,

第二个test_link2是tnsnames.ora文件中配置的目标数据库DMDB的连接信息,

scott/tiger是登录到远程数据库的用户名和密码,然后当在本地数据库使用test_link1的dblink访问远程数据库的时候,会使用scott的身份来访问。

权限解释:

CREATE DATABASE LINK(所创建的DBlink只能是创建者自己使用,别的用户都使用不了)

CREATE PUBLIC DATABASE LINK(public表示所创建的dblink所有用户都可以使用)

3)就是在本地获取远程数据库里的数据了。

select * from test_tb@test_link1

第二种方法(成功了):

create
[public] database link test_link1

connect to scott identified by tiger using '192.168.0.123:1521/mai';

select
* from test_tb@test_link1;

使用第二种方法更简单,不用配置tnsnames.ora文件
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: