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;