返回首页

gbase数据、南大通用产品文档:GBase8c存储过程支持自治事务

更新日期:2024年09月11日

自治事务可以在存储过程中定义,标识符为
PRAGMA
AUTONOMOUS_TRANSACTION,其余语法与创建存储过程语法相同,示例如下。
--建表
create table t2(a int, b int);
insert into t2 values(1,2);
select * from t2;
--创建包含自治事务的存储过程
CREATE OR REPLACE PROCEDURE autonomous_4(a int, b int)
AS
DECLARE
num3 int := a;
num4 int := b;
PRAGMA AUTONOMOUS_TRANSACTION;
BEGIN
insert into t2 values(num3, num4);

GBase 8c V5 开发者手册
南大通用数据技术股份有限公司
722
END;
/
--创建调用自治事务存储过程的普通存储过程
CREATE OR REPLACE PROCEDURE autonomous_5(a int, b int)
AS
DECLARE
BEGIN
insert into t2 values(666, 666);
autonomous_4(a,b);
rollback;
END;
/
--调用普通存储过程
select autonomous_5(11,22);
--查看表结果
select * from t2 order by a;
上述例子,
最后在回滚的事务块中执行包含自治事务的存储过程,
直接说明了自治事务
的特性,即主事务的回滚,不会影响自治事务已经提交的内容。

GBA-01BR-0045
错误码
错误标识
错误显示信息
GBA-01BR-0045

Table MountMap File Error
错误出现原因
表挂载点映射文件错误
分析与建议
检查表mount.map.A 文件的正确性

资源库备份...................................... 114