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?

questionAnswers(3)

yourAnswerToTheQuestion