云数据库 GaussDB-匿名块支持自治事务

时间:2025-02-12 15:08:37

匿名块支持自治事务

自治事务可以在匿名块中定义,标识符为PRAGMA AUTONOMOUS_TRANSACTION,其余语法与创建匿名块语法相同,示例如下。

gaussdb=# create table t1(a int ,b text);CREATE TABLEgaussdb=# START TRANSACTION;START TRANSACTIONgaussdb=# DECLARE PRAGMA AUTONOMOUS_TRANSACTION;BEGINdbe_output.print_line('just use call.');insert into t1 values(1,'you are so cute,will commit!');END;/just use call.ANONYMOUS BLOCK EXECUTEgaussdb=# insert into t1 values(1,'you will rollback!');INSERT 0 1gaussdb=# rollback;ROLLBACKgaussdb=# select * from t1; a |              b---+------------------------------ 1 | you are so cute,will commit!(1 row)

上述例子,最后在回滚的事务块前执行包含自治事务的匿名块,也能直接说明了自治事务的特性,即主事务的回滚,不会影响自治事务已经提交的内容。

support.huaweicloud.com/centralized-devg-v3-gaussdb/gaussdb-42-0792.html