在PostgreSQL中,Portal是一个内部结构,用于暂存查询的执行计划和结果。Portal可以关联到一个事务中,但并不直接跟事务绑定。一个事务可以包含多个Portal,而一个Portal只能属于一个事务。
在PostgreSQL中,事务可以嵌套。最顶层的事务称为顶层事务,它可以包含子事务。当执行一个查询时,它可能会在一个或多个Portal中暂存。如果这个查询是在一个子事务中执行的,那么Portal将在子事务提交或回滚时释放,无论子事务的结果如何。但如果查询是在顶层事务中执行的,Portal将在事务提交或回滚时释放。
以下是一个简单的例子,演示了如何在PostgreSQL中使用Portal和事务:
-- 开启一个新的顶层事务
BEGIN;
-- 创建一个Portal并执行查询
PREPARE my_portal AS SELECT * FROM my_table;
-- 在另一个事务中执行Portal
-- 这个事务可以是子事务
START TRANSACTION;
EXECUTE my_portal;
-- 子事务提交,不管子事务的结果,Portal都会在这里释放
COMMIT;
-- 顶层事务提交,只有当事务提交时,Portal才不可用
COMMIT;
-- Portal不可用,因为事务已经提交
EXECUTE my_portal; -- 错误:prepared statement "my_portal" does not exist
在这个例子中,my_portal
是一个Portal,它被准备来执行一个查询。在子事务中执行这个Portal后,子事务提交,Portal随即释放。尽管Portal不再可用,但如果顶层事务提交,则Portal将保持活跃状态直到顶层事务结束。