CREATE OR REPLACE TRIGGER Net_winnings_trigger
AFTER UPDATE OF total_winnings ON Players
FOR EACH ROW
DECLARE
OldTuple OLD
NewTuple NEW
BEGIN
IF(OldTuple.total_winnings > NewTuple.total_winnings)
THEN
UPDATE Players
SET total_winnings = OldTuple.total_winnings
WHERE player_no = NewTuple.player_no;
END IF;
END;
/
I am trying to get a trigger that will only allow the ‘total_winnings’ field to be updated to a value greater than the current value.
If an update to a smaller value occurs, the trigger should just leave the set the value to the old value (as if the update never occured)
Since you want to override the value that is specified in the
UPDATEstatement, you’d need to use aBEFORE UPDATEtrigger. Something like thisBut overriding the value specified in an
UPDATEstatement is a dangerous game. If this is something that shouldn’t happen, you really ought to raise an error so that the application can be made aware that there was a problem. Otherwise, you’re creating all sorts of potential for the application to make incorrect decisions down the line.