Czy funkcje PostgreSQL są transakcyjne?
Czy funkcja PostgreSQL, taka jak następująca automatycznie, jest transakcyjna?
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;
Innymi słowy, jeśli podczas wykonywania funkcji wystąpi błąd, wszelkie zmiany będąwycofana? Jeśli nie jest to zachowanie domyślne, jak mogę wykonać tę funkcjętransakcyjny?