如何通过dblink truncate远程数据库上的表+调用远程存储过程,提示ORA 02064 .

一般情况下,当我们直接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
----------------
test
SQL> 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
----------------
study
SQL> 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
----------------
study

SQL> 
SQL> select *from test@from_test;

        NO
----------
       100

SQL>  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掉了。

来源:http://www.cnblogs.com/songdavid/articles/2153228.html

-------------------------------------------------------------------------------------------------

本地存储过程调用远程存储过程,提示ORA 02064

       最近在做个项目,需要通过本地的数据库中的存储过程访问远程服务器的存储过程,用来将远程主机中的数据提取过来。 在进行调试的时候发现个问题,存储过程如果放在本地执行都没有问题,只要进行互相调用就会出错。

     今天的程序提示的是:

     ORA-02055   : 分布式更新操作失效:要求回退

    ORA-02064 :不支持分布式操作;

    远程连接到对方服务器以后发现,对方的存储过程中在进行数据提取后,对表进行了COMMIT;而本地程序在调用了对方的存储过程后将数据插入到本地数据库以后也需要进行commit,这样就造成了,远程主机commit一次,本地主机commit一次,对于主过程调用子过程的情况这样的操作是不允许的。

     如果需要commit必须将commit放置在主过程中,否则就会出错。

    将远程主机中的commit取消,然后根据数据的执行情况来返回值给本地过程,用来判断是否提交,这样问题得以解决。

来源:http://blog.csdn.net/lrl_cc/article/details/1713556

-----------------------------------------------------------------------------------------------

客户端使用存储过程调用服务器端的存储过程,报如下错误;

begin p_scs_smsrcpt; end;

ORA-02064: distributed operation not supported
ORA-06512: at "DXYW.PROC_RECEIPT_NEW", line 39
ORA-06512: at "APMS.P_SCS_SMSRCPT", line 23
ORA-06512: at line 1

 

使用JDBC的JAVA程序却能够正常调用执行该过程。

 

咨询系统组的同事,在服务器端的存储过程侧增加如下语句,即将分布式调用设置成为自主提交,问题解决。

 as
PRAGMA AUTONOMOUS_TRANSACTION;

来源:http://blog.sina.com.cn/s/blog_3d5f5dd30100eyeh.html

你可能感兴趣的:(sql,数据库,服务器,table,存储,远程连接)