解决ORA-02021: 不允许对远程数据库进行 DDL 操作下面通过DBLINK调用远程过程来执行这样的操作。
来源:互联网 发布:redis切换数据库命令 编辑:程序博客网 时间:2024/05/18 03:45
如何通过dblink truncate远程数据库上的表
一般情况下,当我们直接truncate一个远程的表的时候,通常会返回如下的错误信息:
ORA-02021: DDL operations are not allowed on a
remote database.
比如下面的示例:
先在数据库test上创建一个test表,并插入一些数据,如下:
SQL> conn toms/toms
已连接。
SQL> select instance_name from v$instance;INSTANCE_NAME----------------testSQL> create table test(no int);表汛唇ā?SQL> insert into test values(100);已创建 1 行。SQL> commit;提交完成然后在另外一个数据库(study)上建一个 dblink,并尝试去truncate test数据库上
toms用户下的test表:
SQL> select instance_name from v$instance;INSTANCE_NAME----------------studySQL> create database link from_test connect to toms
identified by toms using 'local_test';数据库链接已创建。SQL> select * from toms.test@from_test;未选定行SQL> truncate table toms.test@from_test;truncate table toms.test@from_test *ERROR 位于第 1 行:ORA-02021: 不允许对远程数据库进行 DDL 操作SQL> 这时,我们得到了ORA-02021这样的错误,Oracle不允许这么做。那么如果确实有这样的需求,我们该怎么办呢。下面我介绍一个方法:先在test数据库上,建立一个类似如下的procedure:SQL> create or replace procedure proc_truncate_remote_tab(p_tname in varchar2) as 2 BEGIN 3 EXECUTE IMMEDIATE 'TRUNCATE TABLE ' || p_tname; 4 EXCEPTION 5 WHEN OTHERS THEN 6 raise_application_error(-20001,SQLERRM); 7 end; 8 /过程已创建。然后在study数据库上调用test数据库上的这个procedure去完成这个truncate动作:BEGIN proc_truncate_remote_tab@db_link('remote_table_name');END;下面测试验证一下:SQL> select instance_name from v$instance;INSTANCE_NAME----------------studySQL> SQL> select *from test@from_test; NO---------- 100SQL> begin 2 proc_truncate_remote_tab@from_test('test'); 3 end; 4 /PL/SQL 过程已成功完成。SQL> select *from test@from_test;未选定行SQL>
可以看到,远程test数据库上toms用户下的表test已经被truncate掉了。
注释:
在远程的库建立一个存储过程,这个存储过程声明为自治事务,它接受一个参数,可以是你要建立的表名。
过程里面采用动态SQL建表。
然后你就可以远程调用这个过程。
但不知道这样做有什么实用意义。
上述用在远程的库建立一个存储过程的方法,不能解决“将访问本地数据库上一个方案里的表的权限授权给远程数据库上的一个用户”(即如 grant select on tab to user@dblink(或是global name) )的问题.
参考:Your database can't establish connection with remote database at compile time. but you hope that it
0 0
- 解决ORA-02021: 不允许对远程数据库进行 DDL 操作下面通过DBLINK调用远程过程来执行这样的操作。
- 如何通过dblink truncate远程数据库上的表+调用远程存储过程,提示ORA 02064 .
- Oracle 连接远程数据库及远程执行DDL操作--原创
- ORA-02021解决方法--dblink操作ddl
- 调用远程数据库的存储过程出现“ORA-02064不支持分布式操作”错误的解决方法
- 怎么用Delphi来实现对远程服务器oracle 数据库进行定期的操作???
- oracle之使用dblink操作远程数据库
- Oracle通过DBLink操作数据表,报错“ORA-22992:无法使用从远程表选择的lob定位器”
- Oracle通过DBLink操作数据表,报错“ORA-22992:无法使用从远程表选择的lob定位器”
- Oracle通过DBLink操作数据表,报错“ORA-22992:无法使用从远程表选择的lob定位器”
- 对远程的DB进行操作。
- 对远程的数据进行操作
- dblink远程调用存储过程
- oracle通过DBLink访问远程数据库的LOB字段报ORA-22992的解决方法
- oracle通过DBLink访问远程数据库的LOB字段报ORA-22992的解决方法
- 通过secureCRT创建SSH会话,对mysql数据库远程进行操作
- sql 2008 对远程数据库的操作
- linux通过远程访问MySQL数据库,并执行相关操作
- sql 小结
- jquery、css 的选择器(逗号/空格/英文句号/大于号/加号/波浪号)备忘
- window.onbeforeunload的用法
- 基于Qt-Windows平台的Android开发部署
- NSUserDefaults 数据保存
- 解决ORA-02021: 不允许对远程数据库进行 DDL 操作下面通过DBLINK调用远程过程来执行这样的操作。
- MyEclipse构建webService简单案例
- Hadoop常见的45个问题解答记录
- 【剑指offer】链表相关-在o(1)时间删除链表结点13
- 与存储程序有关的数据字典
- JAVA基础必备(二)——数据类型
- linux下oracle 报错集合
- 怎样构造一个正确高效的C++的类的构造函数
- ARP:地址解析协议