mysql创建触发器时报1064错误问题及解决

 更新时间:2023年08月26日 15:48:42   作者:牧野风凉  
这篇文章主要介绍了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可以同时使用。

总结

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

相关文章

  • Navicat Premium15连接云服务器中的数据库问题及遇到坑

    Navicat Premium15连接云服务器中的数据库问题及遇到坑

    这篇文章主要介绍了Navicat Premium15连接云服务器中的数据库问题及遇到坑,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • 数据结构-树(三):多路搜索树B树、B+树

    数据结构-树(三):多路搜索树B树、B+树

    这篇文章主要介绍了多路搜索树B树、B+树,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • mysql 获取当天发布的信息的语句

    mysql 获取当天发布的信息的语句

    mysql 获取当天发布的信息的实现语句,需要的朋友可以参考下。
    2010-03-03
  • mysql中主键索引和联合索引的原理与区别

    mysql中主键索引和联合索引的原理与区别

    索引是帮助MySQL高效获取数据的数据结构,本文主要介绍了mysql中主键索引和联合索引的原理与区别,具有一定的参考价值,感兴趣的可以了解一下
    2024-04-04
  • Mysql数据库不同官方版本对比详细分析

    Mysql数据库不同官方版本对比详细分析

    MySQL是一个流行的开源关系型数据库管理系统,有多个版本,这篇文章主要介绍了Mysql数据库不同官方版本对比的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-01-01
  • MySQL使用TEXT/BLOB类型的知识点详解

    MySQL使用TEXT/BLOB类型的知识点详解

    在本篇文章里小编给大家整理的是关于MySQL使用TEXT/BLOB类型的几点注意内容,有兴趣的朋友们学习下。
    2020-03-03
  • myeclipse中连接mysql数据库示例代码

    myeclipse中连接mysql数据库示例代码

    这篇文章主要为大家详细介绍了MyEclipse连接MySQL数据库图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • Mysql8.0密码问题mysql_native_password和caching_sha2_password详解

    Mysql8.0密码问题mysql_native_password和caching_sha2_password详解

    这篇文章主要介绍了Mysql8.0密码问题mysql_native_password和caching_sha2_password,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • MYSQL批量UPDATE的两种方式小结

    MYSQL批量UPDATE的两种方式小结

    本文主要介绍了两种MySQL批量UPDATE的方式,SQL的foreach循环和使用INSERT...ON DUPLICATE KEY UPDATE,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-11-11
  • 浅谈mysql 自定义函数

    浅谈mysql 自定义函数

    本文主要是分析了一下在工作中写的一个mysql的自定义函数,很简单,仅仅是希望能对大家理解mysql自定义函数有所帮助。
    2014-09-09

最新评论