这里有新鲜出炉的精品教程,程序狗速度看过来!
Oracle Database,又名 Oracle RDBMS,或简称 Oracle。是甲骨文公司的一款关系数据库管理系统。到目前仍在数据库市场上占有主要份额。
本文简述了通过创建 database link 实现 ORACLE 跨数据库查询的方法, 需要的朋友可以参考下
在 Oracle 本地数据库端执行赋权 dbuser 帐号
SQL> grant create database link to dbuser;
1. 配置本地数据库服务器的 tnsnames.ora 文件
- $vi $ORACLE_HOME/network/admin/tnsnames.ora
添加如下行, 其中 DBLINK 为连接名(可自定义),HOST 和 PORT 为数据库侦听的 IP 及端口,SERVICE_NAME 为数据库的 SID,
- MEDIADBLINK =
- (DESCRIPTION =
- (ADDRESS_LIST =
- (ADDRESS = (PROTOCOL = TCP)(HOST = 10.0.0.1)(PORT = 1521))
- )
- (CONNECT_DATA =
- (SERVICE_NAME = db)
- )
- )
2. 登录到本地数据库,创建 database link
执行如下查询语句,其中 MEDIADB 为 database link 名(可自定义),MEDIADBLINK 为先前在 tnsnames.ora 中定义的连接名,
dbuser 为用户名,password 为密码
- -- Create database link
- create database link MEDIADB
- connect to dbuser identified by password
- using 'MEDIADBLINK';
注意:这里不会验证用户名密码的正确性
3. 使用链接的数据库
3.1 查询、删除和插入数据和操作本地的数据库是一样的,只不过表名需要写成 "表名 @database link 名",如
- select * from table_name@MEDIADB ;
3.2 也可以为这个表创建一个同义词
- create synonym aaa
- for table_name@MEDIADB;
如下语句的效果和 3.1 中的一样
- select * from aaa;
删除同义词的语句为
- drop synonym aaa;
以下是其他网友的补充:
在 Oracle 本地数据库端执行赋权 dbuser 帐号
SQL> grant create database link to dbuser;
配置本地数据库服务器的 tnsnames.ora 文件
$ vi $ORACLE_HOME/network/admin/tnsnames.ora
增加需要远程连接服务器的连接配置,如:
- ORCL_REMOTE =
- (DESCRIPTION =
- (ADDRESS = (PROTOCOL = TCP)(HOST = oradb )(PORT = 1521))
- (CONNECT_DATA =
- (SERVER = DEDICATED)
- (SERVICE_NAME = orcl)
- )
- )
登录到本地数据库,创建 database link
执行如下查询语句,其中 ORCL_LINK 为 database link 名(可自定义),ORCL_REMOTE 为先前在 tnsnames.ora 中定义的连接名,
dbuser 为用户名,password 为密码
- create database link ORCL_LINK connect to dbuser identified by password using 'ORCL_REMOTE';
查询创建 database link 的 2 中方式:
1)、执行 SQL 语句。
select * from user_db_links; -- 用户 DB Link
select * from dba_db_links; --dba DB Link
select * from v$dblink; -- 当前 DB Link
2)、在 PL/SQL 中,在左边浏览器中点击 database links 就可以看到数据库链路了。
使用链接的数据库
查询、删除和插入数据和操作本地的数据库是一样的,只不过表名需要写成 "表名 @database link 名",如
- select * from table_name@ORCL_LINK
其它:
删除 database link(本例中是 ORCL_LINK)
SQL> Drop database link ORCL_LINK;
(adsbygoogle = window.adsbygoogle || []).push({});
来源: http://www.phperz.com/article/17/0701/336199.html