金仓数据库KingbaseES 参数 - ora_statement_level_rollback

参数 ora_statement_level_rollback 控制KingbaseES 是否实现类似oracle 语句级的回滚。当该参数打开时,如果事务操作失败,仅会回滚最后一条操作,避免了全部操作的回滚。以下举例展示差异。

create table t1(id integer);



create or replace procedure p1 is

begin

    insert into t1 values(1);

    insert into t1 values('a');

exception when others then

    null;

end;



create or replace procedure p2 is

begin

    insert into t1 values(1);

    begin

        insert into t1 values('a');

    exception when others then

        null;

    end;

end;

注意:例子有进行exception 捕获,如果没有exception 捕获,则不管是oracle ,还是 kingbaseES,这所有操作都回退。

1、Oracle 结果

仅回滚第二条insert 失败的操作。

SQL> truncate table t1;



Table truncated.



SQL> call p1();



Call completed.



SQL> select * from t1;



        ID

----------

         1

2、KingbaseES

当 ora_statement_level_rollback = on时,结果与oracle 相同,只回退最后一个操作。

test=# truncate table t1;

TRUNCATE TABLE

test=# call p1();

CALL

test=# select * from t1;

 id

----

  1

(1 row)

以上例子,p1 , p2 过程执行结果在oracle ,KingbaseES 执行结果相同。

注意:ora_statement_level_rollback 目前仅能支持过程块内语句级回滚,不支持非块内语句级的回滚。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值