дольше чем хотелось бы
есть AFTER триггер на изменение поля в таблице1:
в теле триггерной функции идет update таблицы1 set колонка2 = вычисляемое значение где таблица1.id = new,id
я правильно понимаю что у нас заново идет поиск нужной строки в Таблице1 по индексу ИД, т.е. мы не работаем с текущим значением которое нам и так уже известно
если бы был триггер на BEFORE то было бы достаточно написать
NEW.колонка2 = ...
RETURN NEW
и это значение попало бы в нашу таблицу
но там сложная логика, и переносить из AFTER в BEFORE нет возможности
как можно в AFTER триггере пересохранить значение колонки без дополнительного поиска по ИД? или тут вариантов как кроме переноса в BEFORE нет?
А почему Вы думаете, что "работает дольше чем хотелось бы" вообще связано с "update таблицы1 set колонка2 = вычисляемое значение где таблица1.id = new.id"? А как это он у Вас рекурсивно не вызывается, кстати?
Обсуждают сегодня