MySQL中触发器入门简单实例与介绍

 更新时间:2013年9月19日 01:13  点击:1559

创建触发器。创建触发器语法如下:

CREATE TRIGGER trigger_name trigger_time trigger_event

ON tbl_name FOR EACH ROW trigger_stmt

其中trigger_name标识触发器名称,用户自行指定;

trigger_time标识触发时机,用before和after替换;

trigger_event标识触发事件,用insert,update和delete替换;

tbl_name标识建立触发器的表名,即在哪张表上建立触发器;

trigger_stmt是触发器程序体;触发器程序可以使用begin和end作为开始和结束,中间包含多条语句;


~~说明~~

CREATE TRIGGER <触发器名称>  --触发器必须有名字,最多64个字符,可能后面会附有分隔符.它和MySQL中其他对象的命名方式基本相象.      { BEFORE | AFTER }  --触发器有执行的时间设置:可以设置为事件发生前或后。      { INSERT | UPDATE | DELETE }  --同样也能设定触发的事件:它们可以在执行insert、update或delete的过程中触发。      ON <表名称>  --触发器是属于某一个表的:当在这个表上执行插入、 更新或删除操作的时候就导致触发器的激活. 我们不能给同一张表的同一个事件安排两个触发器。      FOR EACH ROW  --触发器的执行间隔:FOR EACH ROW子句通知触发器 每隔一行执行一次动作,而不是对整个表执行一次。      <触发器SQL语句>  --触发器包含所要触发的SQL语句:这里的语句可以是任何合法的语句, 包括复合语句,但是这里的语句受的限制和函数的一样。    --你必须拥有相当大的权限才能创建触发器(CREATE TRIGGER),如果你已经是Root用户,那么就足够了。这跟SQL的标准有所不同。

~~实例~~

example1:

创建表tab1

 代码如下:

DROP TABLE IF EXISTS tab1;
CREATE TABLE tab1(
    tab1_id varchar(11)
);


创建表tab2

代码如下:

 DROP TABLE IF EXISTS tab2;

 CREATE TABLE tab2(
    tab2_id varchar(11)
 );


创建触发器: t_afterinsert_on_tab1   

作用:增加tab1表记录后自动将记录增加到tab2表中

代码如下:

DROP TRIGGER IF EXISTS t_afterinsert_on_tab1;

 CREATE TRIGGER t_afterinsert_on_tab1
 AFTER INSERT ON tab1
 FOR EACH ROW
BEGIN
    insert into tab2(tab2_id) values(new.tab1_id);
 END;


测试一下

代码如下:

 INSERT INTO tab1(tab1_id) values('0001');


看看结果

 SELECT * FROM tab1;
 SELECT * FROM tab2;
example2:

创建触发器: t_afterdelete_on_tab1   

作用:删除tab1表记录后自动将tab2表中对应的记录删去

DROP TRIGGER IF EXISTS t_afterdelete_on_tab1;

 CREATE TRIGGER t_afterdelete_on_tab1
 AFTER DELETE ON tab1
 FOR EACH ROW
 BEGIN
      delete from tab2 where tab2_id=old.tab1_id;
END;


测试一下 

DELETE FROM tab1 WHERE tab1_id='0001';


看看结果

SELECT * FROM tab1;
SELECT * FROM tab2;


Mysql触发器的执行顺序

先抛出触发器相关的几个问题

3.1   如果before类型的触发器程序执行失败,sql会执行成功吗?

实验如下:

1)在FC_Word.planinfo中建立before触发器:

DELIMITER |
create trigger trigger_before_planinfo_update
before update
ON FC_Word.planinfo FOR EACH ROW
BEGIN
insert into FC_Output.abc (planid) values (New.planid);
END


2)查看:

mysql> select showprob from planinfo where planid=1;

+----------+
| showprob |
+----------+
|        2 |
+----------+

3)执行sql:

update planinfo set showprob=200 where planid=1;

 触发触发器程序;

4)由于不存在FC_Output.abc,before触发器执行失败,提示:

ERROR 1146 (42S02): Table 'FC_Output.abc' doesn't exist

5)再次查看:

mysql> select showprob from planinfo where planid=1;

+----------+
| showprob |
+----------+
|        2 |
+----------+

即修改sql未执行成功。即如果before触发器执行失败,sql也会执行失败。

[!--infotagslink--]

相关文章

  • oracle 存储过程、函数和触发器用法实例详解

    这篇文章主要介绍了oracle 存储过程、函数和触发器用法,结合实例形式详细分析了oralce 存储过程、函数和触发器具体功能、原理、定义、使用方法及相关操作注意事项,需要的朋友可以参考下...2020-07-11
  • MySQL通过触发器解决数据库中表的行数限制详解及实例

    这篇文章主要介绍了MySQL通过触发器解决数据库中表的行数限制详解及实例的相关资料,需要的朋友可以参考下...2017-04-26
  • MySQL触发器运用于迁移和同步数据的实例教程

    这篇文章主要介绍了MySQL触发器运用于迁移和同步数据的实例教程,分别是SQL Server数据迁移至MySQL以及同步备份数据表记录的两个例子,需要的朋友可以参考下...2015-12-14
  • MySQL 触发器详解及简单实例

    这篇文章主要介绍了MySQL 触发器详解及简单实例的相关资料,需要的朋友可以参考下...2017-04-03
  • MySQL触发器 Update触发Insert失败

    这篇文章主要介绍了MySQL触发器 Update触发Insert失败 的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下...2016-07-25
  • 利用SQL Server触发器实现表的历史修改痕迹记录

    在很多应用程序开发中,需要记录某些数据表的历史记录或修改痕迹,以便日后出现数据错误时进行数据排查。这种业务需求,我们可以通过数据库的触发器来轻松实现历史记录功能...2020-07-11
  • mysql触发器实时检测一条语句进行备份删除思路详解

    遇到过这样一个需求,在一张表里会不时出现 “违规” 字样的字段,需要在出现这个字段的时候,把整行的数据删掉,针对这个需求我们该如何操作呢,下面跟随小编看下mysql触发器实时检测一条语句进行备份删除的解决思路,一起看看吧...2021-09-19
  • MySQL中触发器的基础学习教程

    这篇文章主要介绍了MySQL中触发器的基础学习教程,包括对触发器的创建和管理等基本知识,着力推荐!需要的朋友可以参考下...2015-12-14
  • navicat中创建存储过程、触发器和使用游标的简单实例(图文)

    这篇文章主要介绍了navicat中创建存储过程、触发器和使用游标的简单实例,需要的朋友可以参考下...2017-02-19
  • MySQL 触发器的使用和理解

    这篇文章主要介绍了MySQL 触发器的使用和理解,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下...2021-02-25
  • 【转】SQL Server查询数据库所有存储过程、触发器、索引信息SQL分享

    SQL Server查询数据库所有存储过程、触发器、索引信息SQL分享...2020-07-14
  • mysql 触发器用法实例详解

    这篇文章主要介绍了mysql 触发器用法实例详解的相关资料,需要的朋友可以参考下...2017-06-12
  • MySQL触发器trigger的使用

    这篇文章主要介绍了MySQL触发器trigger的使用,触发器是与表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合,需要的朋友可以参考下面文章的具体内容...2021-09-19
  • MySQL中触发器和游标的介绍与使用

    这篇文章主要给大家介绍了关于MySQL中触发器和游标的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-16
  • MySQL 触发器的基础操作(六)

    这篇文章主要为大家详细介绍了MySQL 触发器的基础操作,告诉大家什么是MySQL触发器,如何查看触发器,感兴趣的小伙伴们可以参考一下...2016-09-18
  • 如何使用SQL Server 2005 INSTEAD-OF触发器

      触发器是类似于存储程序的数据库对象,它响应数据库环境下的某个请求。SQL Sever 2005包含3个触发器对象:AFTER,数据定义语言 (DDL)和INSTEAD-OF。   AFTER触发器是...2016-11-25
  • Oracle 触发器trigger使用案例

    Oracle触发器是使用者对Oracle数据库的对象做特定的操作时,触发的一段PL/SQL程序代码器,触发器分为语句级触发器和行级触发器,本文通过案例给大家介绍触发器使用,感兴趣的朋友跟随小编一起看看吧...2022-02-23
  • WPF控件模板与其触发器

    这篇文章介绍了WPF控件模板与其触发器,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2022-06-01
  • SQLServer触发器调用JavaWeb接口的过程详解

    sqlServer要想调用web接口,就要使用自带的存储过程。而这些存储过程2005版本以后默认时关闭的,所以要先开启。对SQLServer触发器调用JavaWeb接口的过程感兴趣的朋友一起看看吧...2021-12-30
  • MySql数据库触发器使用教程

    MySQL从5.0.2版本开始支持触发器,MySQL的触发器和存储过程一样,都是嵌入到MySQL服务器的一段程序,这篇文章主要给大家介绍了关于MySql数据库触发器使用的相关资料,需要的朋友可以参考下...2022-05-31