mysql创建触发器时报1064错误
1.这里有两张表,book和enterbook,book表中的bookid是enterbook的外键,这里想创建一个insert触发器,实现向enterbook表中添加一条数据时,同时也会向book中添加一条数据。
book:
enterbook:
2.通常百度的mysql创建触发器的语句是这样的,
所以就这两个表来说,创建的语句应该是这样的,
虽然运行结果显示的是没错误,但在添加数据的时候,就会一直报错。
在sql语法中有两张表,对于insert操作来说,inserted存放的是要插入的数据,deleted表存放的是被删除的记录。
但是在mysql的语法中,不是inserted表和deleted表,而是new和old表,所以此处触发器语句应该改成:
划重点!!!千万不能漏了分号
mysql触发器for each row解释
程序体或者是
foreachrow每行受影响,触发器都执行,叫行级触发器。oracle触发器中分行级触发器和语句级触发器,可不写foreachrow,无论影响多少行都只执行一次。mysql不支持语句触发器,所以必须写foreachrow;
触发器的old和new
after触发器—是在记录操纵之后触发,是先完成数据的增删改,再触发,触发的语句晚于监视的增删改操作,无法影响前面的增删改动作
before触发器—是在记录操纵之前触发,是先完成触发,再增删改,触发的语句先于监视的增删改,我们就有机会判断,修改即将发生的操作,如:我们在触发之前需要判断new值和old值的大小或关系,如果满足要求就触发,不通过就修改再触发;如:表之间定义的有外键,在删除主键时,必须要先删除外键表,这时就有先后之分,这里before相当于设置了断点,我们可以处理删除外键。
对于INSERT语句, 只有NEW是合法的;对于DELETE语句,只有OLD才合法;对于UPDATE语句,NEW、OLD可以同时使用。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。