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可以同时使用。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
只使用命令对数据库(mysql)以及表进行操作方法(附详细图文)
这篇文章主要介绍了如何只使用命令对数据库(mysql)以及表进行操作方法的相关资料,包括连接数据库、创建和删除数据库、使用数据库、创建表、插入数据、查询数据、更新数据、删除数据、查询表结构、修改表结构和删除表等,需要的朋友可以参考下2025-11-11
详解MySQL数据类型DECIMAL(N,M)中N和M分别表示的含义
关于MySQL数据类型decimal中n和m分别表示什么含义?本文就此问题作了简单论述,并创建相关表进行验证,需要的朋友可以了解下。2017-10-10
MySQL: mysql is not running but lock exists 的解决方法
下面可以参考下面的方法步骤解决。最后查到一个网友说可能和log文件有关,于是将log文件给移除了,再重启MySQL终于OK了2009-06-06


最新评论