172 похожих чатов

Добрый день поправьте если я ошибаюсь: отловил триггер в системе который работает

дольше чем хотелось бы

есть AFTER триггер на изменение поля в таблице1:

в теле триггерной функции идет update таблицы1 set колонка2 = вычисляемое значение где таблица1.id = new,id

я правильно понимаю что у нас заново идет поиск нужной строки в Таблице1 по индексу ИД, т.е. мы не работаем с текущим значением которое нам и так уже известно

если бы был триггер на BEFORE то было бы достаточно написать
NEW.колонка2 = ...
RETURN NEW
и это значение попало бы в нашу таблицу


но там сложная логика, и переносить из AFTER в BEFORE нет возможности

как можно в AFTER триггере пересохранить значение колонки без дополнительного поиска по ИД? или тут вариантов как кроме переноса в BEFORE нет?

1 ответов

3 просмотра

А почему Вы думаете, что "работает дольше чем хотелось бы" вообще связано с "update таблицы1 set колонка2 = вычисляемое значение где таблица1.id = new.id"? А как это он у Вас рекурсивно не вызывается, кстати?

Похожие вопросы

Обсуждают сегодня

type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
45
А чем вам питонисты не угодили?😂
.
79
Можно ли загрузить скрипт py в бота чтобы он работал по нему? как это сделать?
huskadam #RCC Фанат? @hitlerpvp
13
А дин типизация это хорошо или плохо?
Alexey
12
Исходники плюс документация? Вы гоните)) демок хватит всем
zamtmn
11
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Hello. Could you please help me with finding all coordinates within a radius using a spatial index, given that I have a table with coordinates? SET @lng = 37.57925; SET @lat ...
Rinchin G
7
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
76
а что есть "статистика" ? просто подсчет фактов обращения и времен выполнения ?
Сергей
9
Карта сайта