mysql触发器
"NEW . column_name"或者"OLD . column_name".这样在技术上处理(NEW | OLD . column_name)新和旧的列名属于创建了过渡变量("transition variables")。
现在如果student表中的age列的值是20,那么执行了"UPDATE age SET age=22"之后@old的值会变成20,而@new的值将会变成22。
"NEW . column_name"或者"OLD . column_name".这样在技术上处理(NEW | OLD . column_name)新和旧的列名属于创建了过渡变量("transition variables")。
对于INSERT语句,只有NEW是合法的;对于DELETE语句,只有OLD才合法;而UPDATE语句可以在和NEW以及OLD同时使用。下面是一个UPDATE中同时使用NEW和OLD的例子。
CREATE TRIGGER up
BEFORE UPDATE ON student
FOR EACH ROW
BEGIN
SET @old = OLD.age;
SET @new = NEW.age;
END;
现在如果student表中的age列的值是20,那么执行了"UPDATE age SET age=22"之后@old的值会变成20,而@new的值将会变成22。