Личный кабинет
Укажите e-mail, на который будет выслан код восстановления пароля.
На указанный вами адрес e-mail был выслан код подтверждения аккаунта. Введите полученный код для продолжения:
Введите новый пароль два раза:
Postgres Pro предоставляет следующие вспомогательные функции для получения информации в событийных триггерах.
Подробнее о событийных триггерах можно узнать в Главе 39.
Функция pg_event_trigger_ddl_commands возвращает список команд DDL, выполняемых в результате действия пользователя. Вызывать её можно только в функции, реализующей событийный триггер ddl_command_end. При попытке вызвать её в любом другом контексте возникнет ошибка. Функция pg_event_trigger_ddl_commands возвращает одну строку для каждой базовой команды; для некоторых команд, записываемых в виде одного предложения SQL, может возвращаться несколько строк. Эта функция возвращает следующие столбцы:
pg_event_trigger_ddl_commands
ddl_command_end
classid
oid
objid
objsubid
integer
command_tag
text
object_type
schema_name
NULL
object_identity
in_extension
bool
command
pg_ddl_command
Функция pg_event_trigger_dropped_objects возвращает список всех объектов, удалённых командой, вызвавшей событие sql_drop. При вызове в другом контексте pg_event_trigger_dropped_objects выдаёт ошибку. pg_event_trigger_dropped_objects возвращает следующие столбцы:
pg_event_trigger_dropped_objects
sql_drop
original
normal
is_temporary
object_name
address_names
text[]
address_args
pg_get_object_address()
Функцию pg_event_trigger_dropped_objects можно использовать в событийном триггере так:
CREATE FUNCTION test_event_trigger_for_drops() RETURNS event_trigger LANGUAGE plpgsql AS $$ DECLARE obj record; BEGIN FOR obj IN SELECT * FROM pg_event_trigger_dropped_objects() LOOP RAISE NOTICE '% dropped object: % %.% %', tg_tag, obj.object_type, obj.schema_name, obj.object_name, obj.object_identity; END LOOP; END $$; CREATE EVENT TRIGGER test_event_trigger_for_drops ON sql_drop EXECUTE FUNCTION test_event_trigger_for_drops();
В Таблице 9.90 показаны функции, выдающие информацию о таблице, для которой произошло событие перезаписи таблицы (table_rewrite). При попытке вызвать их в другом контексте возникнет ошибка.
table_rewrite
Таблица 9.90. Информация о перезаписи таблицы
pg_event_trigger_table_rewrite_oid()
Oid
pg_event_trigger_table_rewrite_reason()
int
Функцию pg_event_trigger_table_rewrite_oid можно использовать в событийном триггере так:
pg_event_trigger_table_rewrite_oid
CREATE FUNCTION test_event_trigger_table_rewrite_oid() RETURNS event_trigger LANGUAGE plpgsql AS $$ BEGIN RAISE NOTICE 'rewriting table % for reason %', pg_event_trigger_table_rewrite_oid()::regclass, pg_event_trigger_table_rewrite_reason(); END; $$; CREATE EVENT TRIGGER test_table_rewrite_oid ON table_rewrite EXECUTE FUNCTION test_event_trigger_table_rewrite_oid();
Соглашаюсь с условиями обработки персональных данных