search

Home  >  Q&A  >  body text

Try wrapping the CASE/conditional statement inside a MySQL trigger

I have a trigger:

CREATE TRIGGER Moves 
AFTER INSERT ON Rolls
FOR EACH ROW
UPDATE Players
CASE
    WHEN P_Location + NEW.Rolls < 17 THEN
    SET P_Location = P_Location + NEW.Rolls
    WHERE id = NEW.Player_id
    ELSE 
    SET P_Location = NEW.Rolls - (16 - P_Location)
END;

But the syntax is incorrect in some places and generates errors. I've checked for similar questions on this site, but the questions I looked at seemed to use methods that didn't seem to work in this case (specifically using IF ). I want the main condition to be

IF P_Location + NEW.Rolls < 17 THEN
SET P_Location = P_Location + NEW.Rolls
WHERE id = NEW.Player_id

while the ELSE part is

SET P_Location = NEW.Rolls - (16 - P_Location)

Inside the trigger. Can anyone explain how I can do this?

P粉311089279P粉311089279500 days ago1013

reply all(1)I'll reply

  • P粉956441054

    P粉9564410542023-09-12 11:03:52

    The CASE expression must evaluate to a scalar, but you are concatenating other clauses through the CASE expression.

    You can do this so the result of CASE returns a scalar and assign that scalar to the P_Location column.

    UPDATE Players
    SET P_Location = CASE WHEN P_Location + NEW.Rolls < 17
                     THEN P_Location + NEW.Rolls
                     ELSE NEW.Rolls - (16 - P_Location)
                     END
    WHERE id = NEW.Player_id;

    reply
    0
  • Cancelreply