最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL触发器概念、原理与用法详解

来源:懂视网 责编:小采 时间:2020-11-09 21:13:42
文档

MySQL触发器概念、原理与用法详解

MySQL触发器概念、原理与用法详解:本文实例讲述了MySQL触发器概念、原理与用法。分享给大家供大家参考,具体如下: 1、触发器的概念 触发器(trigger)是MySQL提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启
推荐度:
导读MySQL触发器概念、原理与用法详解:本文实例讲述了MySQL触发器概念、原理与用法。分享给大家供大家参考,具体如下: 1、触发器的概念 触发器(trigger)是MySQL提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启

上面是百度给的触发器的概念,我理解的触发器的概念,就是你执行一条sql语句,这条sql语句的执行会自动去触发执行其他的sql语句,就这么简单。

超简说明:sql1->触发->sqlN,一条sql触发多个sql

2、触发器创建的四个要素

(1)监视地点(table)
(2)监视事件(insert/update/delete)
(3)触发时间(after/before)
(4)触发事件(insert/update/delete)

3、创建触发器

需求:在下订单的时候,对应的商品的库存量要相应的减少,即买几个商品就减少多少个库存量。

订单表:ord
商品表:goods

首先来创建表并添加几条数据:

create table goods(
 gid int,
 name varchar(20),
 num smallint
);
create table ord(
 oid int,
 gid int,
 much smallint
);
insert into goods values(1,'cat',40);
insert into goods values(2,'dog',63);
insert into goods values(3,'pig',87);

然后按照触发器创建的四个要素来进行分析:

  • 监视谁:ord(订单表)
  • 监视动作:insert(插入操作)
  • 触发时间:after(在插入操作后触发)
  • 触发事件:update(触发更新操作)
  • 最后创建触发器:

    create trigger t1 
    after
    insert 
    on ord
    for each row
    begin
     update goods set num=num-2 where gid = 1;
    end$
    
    

    分析:触发器的名称为t1,触发时间为after,监视动作为insert,监视ord表,for each row最后在进行讨论,这里先记住就行了,begin和end之间写触发事件,这里是一个update语句。意思是不论我下什么订单,都会把商品编号为1的商品的库存量减去2个。

    注意:先不要运行上面的代码,因为mysql的执行结束标识默认是;。如果运行以上的sql语句,mysql碰到;时会自动停止执行,然后end语句就执行不到了。所以我们需要先将mysql的结束标识符改为其他的字符,一般都选用$或者$$,这里选用$来作为执行的结束标识。使用下面的语句来修改MySQL执行的结束标识。

    delimiter $ //设置MySQL执行结束标志,默认为;
    
    

    4、查看和删除已有的触发器

    (1)查看已有触发器:show triggers
    (2)删除已有触发器:drop trigger triggerName

    5、触发器中引用行变量

    (1)在触发目标上执行insert操作后会有一个新行,如果在触发事件中需要用到这个新行的变量,可以用new关键字表示
    (2)在触发目标上执行delete操作后会有一个旧行,如果在触发事件中需要用到这个旧行的变量,可以用old关键字表示
    (3)在触发目标上执行update操作后原纪录是旧行,新记录是新行,可以使用new和old关键字来分别操作

    当下订单时减少相应的货品的库存量,创建触发器:

    create trigger t2
    after
    insert 
    on ord
    for each row
    begin
     update goods set num=num-new.much where gid=new.gid;
    end$
    
    

    当删除订单时增加相应的修改货品的库存量,创建触发器:

    create trigger t3
    after
    delete
    on ord
    for each row
    begin
     update goods set num=num+old.much where gid=old.gid;
    end$
    
    

    当更新订单的购买数修改相应的修改货品的库存量,创建触发器:

    create trigger t4
    before 
    update
    on ord
    for each row
    begin
     update goods set num=num+old.much-new.much where gid = new.gid;
    end$
    
    

    6、after和before的区别

    after操作,是在执行了监视动作后,才会执行触发事件
    before操作,是在执行了监视动作前,会执行触发事件
    两者在一般的触发器中并没有什么区别,但是有的时候有区别,如:

    需求:在用户定了超过库存的订单后,会修改该订单的订购数量,使订购数量的最大值和库存量相同 分析:首先判断 订购量 > 库存量,然后做将订购量改为库存量

    创建触发器:

    create trigger t5
    before
    insert 
    on ord
    for each row
    begin
     declare restNum int;
     select num into restNum from goods where gid = new.gid;
     if new.much > restNum then
     set new.much = restNum;
     end if;
     update goods set num=num-new.much where gid=new.gid;
    end$
    
    

    注意:这里如果使用的是after就会报错,如果使用的是after,就会先执行insert操作,也就是插入订单操作,然后在进行判断下单数量和库存量,得出新的下单数量,可是已经执行了下单操作了,所以就会报错。这里必须使用before操作。

    7、for each row是干什么的?

    在oracle触发器中,触发器分为行触发器和语句触发器

    比如:

    create trigger tn
    after
    update
    on xxtable
    for each row #每一行受影响,触发事件都执行,叫做行触发器
    begin
     sqlN;
    end$
    
    

    执行:

    update xxtable set xxx=xxx where id>100;
    
    

    该修改操作假设100行,那么sqlN,会触发多少次?答案:会触发100次。

    拓展:

    在oracle中,for each row如果不写,无论update语句一次影响了多少行,都只执行一次触发事件。
    比如:1人下了订单,买了5件商品,insert 5次,可以用行级触发器,修改5次库存;用语句级触发器触发,insert一条发货提醒。
    遗憾的是mysql目前不支持语句级触发器。

    更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

    希望本文所述对大家MySQL数据库计有所帮助。

    您可能感兴趣的文章:

  • MySQL触发器使用详解
  • MYSQL设置触发器权限问题的解决方法
  • mysql 触发器实现两个表的数据同步
  • Mysql中的触发器简单介绍及使用案例
  • 如何测试mysql触发器和存储过程
  • MySQL笔记之触发器的应用
  • MySQL与SQL的触发器的不同写法
  • MySQL如何创建触发器
  • MySQL触发器运用于迁移和同步数据的实例教程
  • MySQL触发器学习总结
  • 声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文档

    MySQL触发器概念、原理与用法详解

    MySQL触发器概念、原理与用法详解:本文实例讲述了MySQL触发器概念、原理与用法。分享给大家供大家参考,具体如下: 1、触发器的概念 触发器(trigger)是MySQL提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启
    推荐度:
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top