mysql 触发器开荒

Posted 没有梦想-何必远方

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 触发器开荒相关的知识,希望对你有一定的参考价值。

mysql触发器平常没怎么用到过,这次用到了,感觉特别方便。简单总结一下用法。

先看一下我写的这两个触发器:

/*更新触发器*/
DROP TRIGGER IF EXISTS t_update_on_t_tradefee;
CREATE TRIGGER t_update_on_t_tradefee 
BEFORE UPDATE ON t_tradefee 
FOR EACH ROW
BEGIN
         IF (NEW.margin_profit - OLD.margin_profit)!=0 
         THEN
     insert into t_margin_profit(cardno,op_time,price,t_tradeFee_id) values(SUBSTRING(new.cardno,1,3),NOW(),NEW.margin_profit - OLD.margin_profit,NEW.id);
         END IF;

END;
/*添加触发器*/
DROP TRIGGER IF EXISTS t_insert_on_t_tradefee;
CREATE TRIGGER t_insert_on_t_tradefee
AFTER INSERT ON t_tradefee
FOR EACH ROW
BEGIN
         IF new.margin_profit!=0 then
     insert into t_margin_profit(cardno,op_time,price,t_tradeFee_id) values(SUBSTRING(new.cardno,1,3),NOW(),NEW.margin_profit,NEW.id);          
         END IF;    
END;

需要注意的是:

  • if判断里面不能有空格,这里就是!=0前后,否则报错。
  • 更新触发器如果要用到改变前后的值需要使用before update 而不是after,NEW.margin_profit - OLD.margin_profit 这里就是margin_profit列改变后的值-改变前的值。

以上是关于mysql 触发器开荒的主要内容,如果未能解决你的问题,请参考以下文章

MySQL触发器

如何设置 vscode 的代码片段,以便在自动完成后自动触发 vscode 的智能感知?

给课题组师弟师妹们的开荒手册

片段创建的 Intent 不会触发 onNewIntent

导航到另一个片段时触发 API 调用

新书上市 | NetLogo开荒之作!