Oto przykład wyzwalacza, który zadziała. Pamiętaj, że będziesz potrzebować zarówno wyzwalaczy aktualizacji, jak i wstawiania ze względu na wymagania dotyczące „aktualizacji ad hoc”.
delimiter ~
create trigger my_table_update before update on my_table
for each row begin
set new.grand_total = new.item_price - new.discount + new.delivery_charge;
end~
create trigger my_table_insert before insert on my_table
for each row begin
set new.grand_total = new.item_price - new.discount + new.delivery_charge;
end~
delimiter ;
Ale czy widok nie byłby prostszy i lepszy?
create view my_table_view as
select item_price, discount, delivery_charge,
item_price - discount + delivery_charge as grand_total
from my_table;
następnie po prostu wybierz z widoku zamiast z tabeli