I am trying to put a constraint on a database where if generic_asset.type = 'raw' then generic_asset.atomic = 1 must be maintained. For this I wrote the following trigger of type BEFORE INSERT. Here is the snippet:
DELIMITER //
CREATE TRIGGER generic_asset_check BEFORE INSERT ON generic_asset FOR EACH ROW
BEGIN
IF NEW.type = 'raw' THEN
BEGIN
IF NEW.atomic = 0 THEN
SET SQLSTATE = 'Sorry cannot insert';
END IF;
END IF;
END //
DELIMITER ;
Error is like:
#1064 - syntax error near 'SQLSTATE = 'Sorry cannot insert';
END IF;
END IF;
END' in line 6
(translated from French).
I tried various syntax but all seam not to work and also knowing that my changes are so little like changing double quotes, removing BEGIN with END IF;... So I know these turns are irreverent.
I revised syntax in many internet resources and official documentation, nothing helped.