灯火阑珊ya 2021-12-16 17:21 采纳率: 50%
浏览 72

MYSQL触发器怎么写?

问题遇到的现象和发生背景

按照书上例子写报错,但不理解,不会改

问题相关代码,请勿粘贴截图
mysql> CREATE TRIGGER Student_Count
    -> AFTER INSERT ON Student
    -> REFERENCING
    -> NEW TABLE AS DELTA
    -> FOR EACH STATEMENT
    -> INSERT INTO StudentInsertLog(Numbers)
    -> SELECT COUNT(*)FROM DELTA;

运行结果及报错内容

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'REFERENCING
NEW TABLE AS DELTA
FOR EACH STATEMENT
INSERT INTO StudentInsertLog(N' at line 3

我想要达到的结果

将每次对表Student的插入操作所增加的学生个数记录到表StudentInsertLog中

  • 写回答

2条回答 默认 最新

  • 关注

    参考:

    CREATE OR REPLACE TRIGGER TRI_DELETE_INFO
      AFTER DELETE ON T_INFO_2012
      REFERENCING OLD AS OLD NEW AS NEW
      FOR EACH ROW
    DECLARE
      V_SQLERRM VARCHAR2(200);
    BEGIN
      DELETE FROM T_INFO_2013 WHERE CODE = :OLD.CODE;
      --COMMIT; 触发器中不可以使用COMMIT;
    EXCEPTION
      WHEN OTHERS THEN
        V_SQLERRM := '触发器 TRI_DELETE_INFO 出错:' || SQLERRM;
        INSERT INTO PROCEDURE_LOG
          (ERRMSG, ERRDATE)
        VALUES
          (V_SQLERRM, SYSDATE);
    END;
    
    评论 编辑记录

报告相同问题?

问题事件

  • 创建了问题 12月16日

悬赏问题

  • ¥15 为什么apriori的运行时间会比fp growth的运行时间短呢
  • ¥15 帮我解决一下膳食平衡的线性规划模型的数据实例
  • ¥40 万年历缺少农历,需要和阳历同时显示
  • ¥250 雷电模拟器内存穿透、寻基址和特征码的教学
  • ¥200 比特币ord程序wallet_constructor.rs文件支持一次性铸造1000个代币,并将它们分配到40个UTXO上(每个UTXO上分配25个代币),并设置找零地址
  • ¥15 关于Java的学习问题
  • ¥15 如何使用chatgpt完成文本分类任务?
  • ¥15 已知速度v关于位置s的等式,怎么转化为已知位置求速度v的等式
  • ¥15 我有个餐饮系统,用wampserver把环境配置好了,但是后端的网页却进去,是为什么,能不能帮远程一下?
  • ¥15 R运行没有名称为"species"的插槽对于此对象类"SDMmodelCV"