我使用的是Oracle 11g快递版。 我已经创建了表,存储过程,它工作正常。 我的用户名为“System”,密码为“xyz”(安装时为主用户)。
然后我用同一个用户创建了两个数据库“abc”和“pqr”。
我想创建从abc到pqr的数据库链接。
create database link testlink
connect to pqr identified by xyz
using '(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=localhost)(PORT=1521)) (CONNECT_DATA=(sid=xe)))';
我收到错误“权限不足”。 请帮帮我。
答案 0 :(得分:0)
应该是CONNECT TO
用户名而不是数据库名称,如下图所示,其中描述了CREATE DATABASE LINK
的语法。我们在USING connect_string
子句下定义数据库实例/服务。
先决条件
要创建专用数据库链接,您必须具有
CREATE DATABASE LINK
系统特权。要创建公共数据库链接,您必须具有CREATE PUBLIC DATABASE LINK
系统特权。此外,您必须具有远程Oracle数据库的CREATE SESSION
系统特权。
<强> 参考: 强> CREATE DATABASE LINK
<强> 演示 强>
[oracle@orcl Desktop]$ sqlplus system/oracle
SQL> create user abc identified by abc;
User created.
SQL> create user xyz identified by xyz;
User created.
SQL> grant create session to abc;
Grant succeeded.
SQL> conn abc/abc
Connected.
SQL> create database link testlink connect to pqr identified by pqr using '(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=orcl.dba.com)(PORT=1522)) (CONNECT_DATA=(service=orcl)))';
create database link testlink connect to pqr identified by pqr using '(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=orcl.dba.com)(PORT=1522)) (CONNECT_DATA=(service=orcl)))'
*
ERROR at line 1:
ORA-01031: insufficient privileges
SQL> conn system/oracle
Connected.
SQL> grant create database link to abc;
Grant succeeded.
SQL> create database link testlink connect to pqr identified by pqr using '(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=orcl.dba.com)(PORT=1522)) (CONNECT_DATA=(service=orcl)))';^[[3~^C
SQL> conn abc/abc
Connected.
SQL> create database link testlink connect to pqr identified by pqr using '(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=orcl.dba.com)(PORT=1522)) (CONNECT_DATA=(service=orcl)))';
Database link created.