在 Oracle 数据库中,经常需要跨实例、跨服务器访问其他数据库中的表。DATABASE LINK 是 Oracle 官方提供的标准解决方案——它能够在本地数据库中建立一个指向远端数据库的逻辑连接,使查询操作像操作本地表一样简单自然。
创建公共数据库链接的语法如下:
CREATE PUBLIC DATABASE LINK db_link_name
CONNECT TO username IDENTIFIED BY password
USING '(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = visit_ip)(PORT = visit_port))
)
(CONNECT_DATA =
(SERVICE_NAME = SID)
)
)';
以下几个参数需要重点关注:
username / password — 远端数据库的登录账号与密码;
visit_ip — 远端数据库所在主机的 IP 地址;
visit_port — 数据库监听端口(默认通常为 1521);
SID — 远端数据库的实例名称。

创建成功后,查询远端表时只需在表名后附加 @db_link_name:
SELECT * FROM 表名@db_link_name;
如此一来,本地查询即可直接获取远端数据,无需借助额外的中间件或手动导出导入操作。需要注意的是,使用公共链接后,所有具备权限的用户都可以通过该链接访问远端数据库,因此安全策略需要在创建前做好规划。
