zoukankan      html  css  js  c++  java
  • mysql教程-触发器

    触发器

      1. mysql触发器 情景说明

      情景设置,如图,当我们点击了购买,将会发生什么?

      

    触发器

     

      现有如下两张表

      商品表

      编号(id)名称(name)价格(price)库存(stock)

      1F2战斗机10000100

      2法拉利80070

      3航空母舰500020

      4三栖交通工具100050

      订单表

      编号(id)商品编号(tid)购买数量(num)下单时间(order_time)

      我们现在要买5架F2战斗机,下一个订单,需要做什么?

      传统的做法:

      insert into ord(tid,num) values(1,5);

      update traffic set stock = stock - 5 where id = 1;

      新的方式:

      我们可以使用触发器,一触即发!!

      2.mysql触发器使用:trigger

      

    触发器

     

      2.1 触发器四要素:

      地点:(表,table),

      监视的事件:(insert,delete,update)

      时间:(before/after)

      触发的事件:(insert,delete,update)

      2.2创建触发器的语法:

      

    触发器

     

      注意:在写触发器之前,要更改的mysql的分隔符。

      监视事件和触发事件之间如何传递值?

      需求:现在我们要购买 10辆法拉利, 商品表里的触发器应该 这样写:

      #商品表的触发器

      delimiter $

      create triggter tg1

      after //事件触发在 下订单之后

      insert // 监视插入事件

      on order // 监视 order订单表

      for each row

      begin

      update traffic set stock=stock- new,num where id= new id;

      end $

      在order表的操作:

      insert into(tid,num) values(2,10);

      以下分析均对于 order表而言

      对于insert而言,

      

    触发器

     

      新旧关系

      New表示是新插入的一行,

      要引用其中的tid和num,如何引用?

      New.tid

      new.num

      对于delete而言:

      

    触发器

     

      对于update而言

      

    触发器语法

     

      需求:先购买了10个辆法拉利,然后要把数量更改为5,写出触发器;

      #商品表的触发器

      mysql> delimiter $

      mysql> create trigger tg3

      -> after

      -> update

      -> on ord

      -> for each row

      -> begin

      -> update traffic set stock = stock + old.num - new.num where id = new.tid;

      -> end $

      [关于before]

      有没有before的情况。

      After:在监视事件发生之后触发的,触发事件要晚于监视事件。

      Before:在监视事件发生之前触发的,触发事件要早于监视事件。

      需求:若订单数量超过10的话,就认为是恶意订单,只让其购买10个。

      #商品表的触发器

      mysql> delimiter $

      mysql> create trigger tg4

      -> before

      -> insert

      -> on ord

      -> for each row

      -> begin

      -> if new.num > 10 then

      -> set new.num = 10;

      -> end if;

      -> update traffic set stock = stock - new.num where id = new.tid;

      -> end $

      3.触发器应用场合

      1.当向一张表中添加或删除记录时,需要在相关表中进行同步操作。

      比如,当一个订单产生时,订单所购的商品的库存量相应减少。

      2.当表上某列数据的值与其他表中的数据有联系时。

      比如,当某客户进行欠款消费,可以在生成订单时通过设计触发器判断该客户的累计欠款是否超出了最大限度。

      3.当需要对某张表进行跟踪时。

      比如,当有新订单产生时,需要及时通知相关人员进行处理,此时可以在订单表上设计添加触发器加以实现

  • 相关阅读:
    数据表后缀问题
    window.history.go(-1)返回且刷新页面
    mysql性能优化-慢查询分析、优化索引和配置
    从数据库、代码和服务器对PHP网站Mysql做性能优化
    什么是WEBserver? 经常使用的WEBserver有哪些?
    浅谈 C/S 和 B/S 架构
    Android常用开源项目
    csdn android视频播放器开发
    视频会议十大开源项目排行
    Android开源项目大全
  • 原文地址:https://www.cnblogs.com/huidaoli/p/3232282.html
Copyright © 2011-2022 走看看