ORA-02021: DDL operations are not allowed on a remote database
2.创建dblink时,可以使用连接字符串(与tnsname.ora中的),效率较高。
---------------------------------------------------------------------------------------------------------------------------------------------------------------------
注意:创建数据库链接的帐号必须有CREATE DATABASE LINK或CREATE PUBLIC DATABASE LINK的系统权限,用来登录到远程数据库的帐号必须有CREATE SESSION权限。这两种权限都包含在CONNECT角色中(CREATE PUBLIC DATABASE LINK权限在DBA中)。
两台不同的数据库服务器,从一台数据库服务器的一个用户读取另一台数据库服务器下的某个用户的数据,这个时候可以使用 dblink。
其实dblink和数据库中的view差不多,建dblink的时候需要知道待读取数据库的ip地址,ssid以及数据库用户名和密码。
创建可以采用两种方式:
1、已经配置本地服务
create public database
link fwq12 connect to fzept
identified by neu using ‘fjept‘ Create DATABASE LINK 数据库链接名CONNECT TO 用户名 IDENTIFIED BY 密码 USING ‘本地配置的数据的实例名’;
2、未配置本地服务
create database link linkfwq
connect to fzept identified by neu
using ‘(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 10.142.202.12)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = fjept)
)
)‘;
host=数据库的ip地址,service_name=数据库的ssid。
其实两种方法配置dblink是差不多的,我个人感觉还是第二种方法比较好,这样不受本地服务的影响。
create database link hr_tables
connect to manbu
identified by "admin"
using ‘WALK‘
其中hr_tables是远程数据库的一个别名
manbu是远程数据库的数据库用户名
admin为manbu的密码
WALK为数据库在本地数据库的SID (具体说是本地数据库服务器的服务名。需要在本地服务器tnsname.ora上建立一个服务。而不是在客户端建。)
接着,我们可以做一下测试,比如我们想拿到数据库的某一张表数据,那我们可以在命名行下做如下的测试:
select user_name from mall_user@hr_tables;
每一张表都必须加上@hr_tables字符串,表示该表是dblink所指向的远程数据库的表单
或者,你会觉得这样子很麻烦,那我们可以为mall_user@hr_tables配置一个别名,那就没有改须麻烦啦。
创建mall_user@hr_tables的同义词,也即别名:
create synonym mall_user for mall_user@hr_tables;