mysql触发器中, NEW关键字,和 MS SQL Server 中的 INSERTED 和 DELETED 类似,MySQL 中定义了 NEW 和 OLD,用来表示触发器的所在表中,触发了触发器的那一行数据。
具体地:
在 INSERT 型触发器中,NEW 用来表示将要(BEFORE)或已经(AFTER)插入的新数据;
在 UPDATE 型触发器中,OLD 用来表示将要或已经被修改的原数据,NEW 用来表示将要或已经修改为的新数据;
在 DELETE 型触发器中,OLD 用来表示将要或已经被删除的原数据;
使用方法: NEW.columnName (columnName 为相应数据表某一列名)
另外,OLD 是只读的,而 NEW 则可以在触发器中使用 SET 赋值,这样不会再次触发触发器,造成循环调用。
原文链接:https://blog.csdn.net/bcfdsagbfcisbg/article/details/78338434
#insert之前
CREATE TRIGGER tb_merchant_user_encryption_insert
BEFORE INSERT ON tb_merchant_user FOR EACH ROW
BEGIN
if new.login_name is not null then
set new.login_name=aes_encrypt(new.login_name, ‘login_name’);
end if;
END;
#update之前把
CREATE TRIGGER tb_merchant_user_encryption_update
BEFORE UPDATE ON tb_merchant_user FOR EACH ROW
BEGIN
if new.login_name is not null then
set new.login_name=aes_encrypt(new.login_name, ‘login_name’);
end if;
END;
is not null 在 new.login_name为null 时会失效 改为 null!=new.login_name
如需加入字符判断 length(trim(new.login_name))>0