在Navicat for MySQL 中怎么创建触发器?

在Navicat for MySQL 中怎么创建触发器?,第1张

将delimiter 更改为delimiter //\x0d\x0a如下:\x0d\x0amysql>delimiter //\x0d\x0amysql>create trigger insertArticle_Trigger after insert on article1\x0d\x0a->for each row\x0d\x0a->begin\x0d\x0a->update board1 set articleCount = articleCount+1 where id=new.bid\x0d\x0a->end\x0d\x0a->//\x0d\x0a\x0d\x0a执行如下语句,可查看到board1表articleCount被更改:\x0d\x0amysql>delimiter \x0d\x0amysql>insert into article1 values(1)\x0d\x0a\x0d\x0a其中delimiter作用:\x0d\x0a告诉mysql解释器,该段命令是否已经结束了,mysql是否可以执行了。 \x0d\x0a默认情况下,delimiter是分号。在命令行客户端中,如果有一行命令以分号结束, 那么回车后,mysql将会执行该命令。但有时候,不希望MySQL这么做。在为可能输入较多的语句,且语句中包含有分号。使用delimiter //,这样只有当//出现之后,mysql解释器才会执行这段语句。详见

1、先创建一个空的person_log表用来存放被删除的记录。

2、创建一个触发器del_person,执行删除 *** 作后将记录插入到person_log表。

触发器person_log

3、从person表中执行删除记录 *** 作来触发事件

4、查看person_log表结果:

结果:从person表执行删除一条记录后会触发person_log表中增加被删除的记录。

触发器是与表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合,触发器这种特性可以协助应用在数据库端确保数据的完整性。

触发器只能创建在永久表上,不能对临时表创建触发器。其中trigger_time是触发器的时间,可以使BEFORE或者AFTER,BEFORE的含义指在检查约束前触发,而AFTER是在检查约束后触发。

删除触发器

一次可以删除一个触发程序,如果没有指定schoma_name,默认为当前数据库。

查看触发器

可以通过执行SHOW TRIGGERS 命令查看触发器的状态、语法等信息,但是因为不能查询指定的触发器,所以每次都返回所有触发器的信息,使用起来不是很方便。

触发器使用

触发器使用有两个限制:

处发程序不能调用将数据返回客户端的存储程序,也不能使用采用CALL语句的动态SQL语句,但是允许存储程序通过参数将数据返回触发器。

不能再触发器中使用以显示或隐士方式开始或结束事物语句。

MYSQL的触发器是按照BEFORE触发器、行 *** 作、AFTER触发器的顺序执行的,其中任何一步 *** 作发生错误都不会继续执行剩下的 *** 作,那么会整个作为一个事物被回滚(Rollback),但是如果是对事物非事物表进行 *** 作,那么已经更新的记录将无法回滚,这也是设计触发器的时候需要注意的问题


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7299661.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-04
下一篇 2023-04-04

发表评论

登录后才能评论

评论列表(0条)

保存