视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MySQL中触发器入门简单实例与介绍
2020-11-09 21:06:32 责编:小采
文档


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

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 <触发器名称>  --触发器必须有名字,最多个字符,可能后面会附有分隔符.它和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也会执行失败。

您可能感兴趣的文章:

  • MySQL中触发器的基础学习教程
  • MySQL触发器使用详解
  • MYSQL设置触发器权限问题的解决方法
  • mysql触发器(Trigger)简明总结和使用实例
  • Mysql中的触发器简单介绍及使用案例
  • Mysql触发器在PHP项目中用来做信息备份、恢复和清空
  • 下载本文
    显示全文
    专题