是一个Postgresql函数,如下面的自动事务处理?
CREATE OR REPLACE FUNCTION refresh_materialized_view(name) RETURNS integer AS $BODY$ DECLARE _table_name ALIAS FOR $1; _entry materialized_views%ROWTYPE; _result INT; BEGIN EXECUTE 'TRUNCATE TABLE ' || _table_name; UPDATE materialized_views SET last_refresh = CURRENT_TIMESTAMP WHERE table_name = _table_name; RETURN 1; END $BODY$ LANGUAGE plpgsql VOLATILE SECURITY DEFINER;
函数是调用它们的事务的一部分。如果事务回滚,它们的效果会回滚。如果事务提交,它们的工作提交。任何BEGIN … EXCEPT函数中的块都像(和在引擎盖下使用)保存点,如SAVEPOINT和ROLLBACK TO SAVEPOINT sql语句。
该函数完全成功或完全失败,禁止BEGIN … EXCEPT错误处理。如果在函数内部发生错误并且未处理,则调用函数的事务将中止。中止的事务不能提交,如果他们尝试提交COMMIT被视为ROLLBACK,与任何其他事务错误一样。观察:
regress=# BEGIN; BEGIN regress=# SELECT 1/0; ERROR: division by zero regress=# COMMIT; ROLLBACK
查看事务(由于零分区而处于错误状态)如何回滚COMMIT?
如果调用没有明确环绕事务的函数,规则与任何其他Pg语句完全相同:
BEGIN; SELECT refresh_materialized_view(name); COMMIT;
(如果SELECT引发错误,COMMIT将失败)。
Postgresql并不支持函数中的自治事务,其中过程/函数可以独立于调用事务提交/回滚。这可以通过dblink使用新会话来模拟。