mysql触发器——NEW与OLD aes_encrypt AES_DECRYPT

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

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值