mysql创建触发器时报1064错误问题及解决
作者:牧野风凉
这篇文章主要介绍了mysql创建触发器时报1064错误问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
mysql创建触发器时报1064错误
1.这里有两张表,book和enterbook,book表中的bookid是enterbook的外键,这里想创建一个insert触发器,实现向enterbook表中添加一条数据时,同时也会向book中添加一条数据。
book:
enterbook:
2.通常百度的mysql创建触发器的语句是这样的,
CREATE TRIGGER 触发器名 BEFORE (AFTER) 触发事件 ON 表名 FOR EACH ROW BEGIN 执行语句列表 END
所以就这两个表来说,创建的语句应该是这样的,
create trigger trigger_1 after insert on enterbook for each row begin insert into book(bookid,bookname,writer,publisher,publishdate,quantity,price) values(bookid,bookname,writer,publisher,publishdate,quantity,price); end;
虽然运行结果显示的是没错误,但在添加数据的时候,就会一直报错。
在sql语法中有两张表,对于insert操作来说,inserted存放的是要插入的数据,deleted表存放的是被删除的记录。
但是在mysql的语法中,不是inserted表和deleted表,而是new和old表,所以此处触发器语句应该改成:
create trigger trigger_1 after insert on enterbook for each row begin insert into book(bookid,bookname,writer,publisher,publishdate,quantity,price) values(new.bookid,new.bookname,new.writer,new.publisher,new.publishdate,new.quantity,new.price); end;
划重点!!!千万不能漏了分号
mysql触发器for each row解释
create trigger mytrigger alert insert on t_a for each row begin insert into t_b set name=new.name, set number=new number;
程序体或者是
set @name=new.name; set @number=new.number; insert into t_b (name,number) values (@name,@number); end
- foreachrow每行受影响,触发器都执行,叫行级触发器。
- oracle触发器中分行级触发器和语句级触发器,可不写foreachrow,无论影响多少行都只执行一次。
- mysql不支持语句触发器,所以必须写foreachrow;
触发器的old和new
after触发器—是在记录操纵之后触发,是先完成数据的增删改,再触发,触发的语句晚于监视的增删改操作,无法影响前面的增删改动作
before触发器—是在记录操纵之前触发,是先完成触发,再增删改,触发的语句先于监视的增删改,我们就有机会判断,修改即将发生的操作,如:我们在触发之前需要判断new值和old值的大小或关系,如果满足要求就触发,不通过就修改再触发;如:表之间定义的有外键,在删除主键时,必须要先删除外键表,这时就有先后之分,这里before相当于设置了断点,我们可以处理删除外键。
- 对于INSERT语句, 只有NEW是合法的;
- 对于DELETE语句,只有OLD才合法;
- 对于UPDATE语句,NEW、OLD可以同时使用。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。