Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > mysql创建触发器时报1064错误

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

触发器的old和new

after触发器—是在记录操纵之后触发,是先完成数据的增删改,再触发,触发的语句晚于监视的增删改操作,无法影响前面的增删改动作

before触发器—是在记录操纵之前触发,是先完成触发,再增删改,触发的语句先于监视的增删改,我们就有机会判断,修改即将发生的操作,如:我们在触发之前需要判断new值和old值的大小或关系,如果满足要求就触发,不通过就修改再触发;如:表之间定义的有外键,在删除主键时,必须要先删除外键表,这时就有先后之分,这里before相当于设置了断点,我们可以处理删除外键。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文