KingbaseES 参数 - ora_statement_level_rollback
参数 ora_statement_level_rollback 控制KingbaseES 是否实现类似oracle 语句级的回滚。当该参数打开时,如果事务操作失败,仅会回滚最后一条操作,避免了全部操作的回滚。以下举例展示差异。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | 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 失败的操作。
1 2 3 4 5 6 7 8 9 10 11 12 13 | 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 相同,只回退最后一个操作。
1 2 3 4 5 6 7 8 9 | test=# truncate table t1; TRUNCATE TABLE test=# call p1(); CALL test=# select * from t1; id ---- 1 (1 row) |
3、PG
可以看到,所有操作全部回退。
1 2 3 4 5 6 7 8 | test=# delete from t1; DELETE 1 test=# call p1(); CALL test=# select * from t1; id ---- (0 rows ) |
以上例子,p1 , p2 过程执行结果在oracle , pg , KingbaseES 执行结果相同。
注意:ora_statement_level_rollback 目前仅能支持过程块内语句级回滚,不支持非块内语句级的回滚(而oracle 支持)。
KINGBASE研究院
分类:
数据库运维
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!