oracle 创建dblink访问远程数据库

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

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

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文件











你可能感兴趣的:(数据库)