zoukankan      html  css  js  c++  java
  • 触发器实现原理

    -----触发器实现原理------

    触发器:triiger 实现为某张表绑定好一段代码,当表中的默写内容发生改变的时候(增删查改)系统会自动触发代码,执行

    触发器的基本要素:事件类型,触发时间 触发对象

    事件类型:增删改 insert delete update
    触发时间:前后 before 和 after
    触发对象:表中的每一条记录(行)

    一张表中只能有一种触发时间的一种类型的触发器,最多一张表能有6个触发器

    触发器创建事例:


    首先创建表


    ①商品表:
    create table my_goods(
    id int primary key auto_increment,
    name varchar(20) not null,
    price decimal(10,2) default 1,
    inv int comment '库存数量')charset utf8;

    ②添加数据
    insert into my_goods values(null,'iphone8',5399,100),(null,'vivoX20',8999,100);

    ③订单表:
    create table my_order(
    id int primary key auto_increment,
    g_id int not null comment '商品id',
    g_number int comment '商品数量'
    )charset utf8;


    命令行运行建表

    --触发器:订单生成一个,商品库存减少一个

    --临时修改语句结束符
    delimiter $$

    create triiger after_order after insert on my_order for each row

    begin --触发器内容

    update my_goods set inv=inv-1 where id=2;

    end --触发器结束

    $$

    delimiter ;


    命令行运行 创建触发器成功 =    =

                  =

    查看触发器:

    show triggers;
    show triggersG;

    查看触发器创建语句:

    show create trigger 触发器名称(eg:after_orderG)

    注:所有的触发器都存储在一张表中 information_shema.triggers

    select * from information_shema.triggerG

  • 相关阅读:
    MVC传递数据的方式
    c#面向对象的多态
    使用扩展方法创建 HTML Helper
    了解视图、视图数据和 HTML Helper
    十种技能方法提高IT人薪酬
    ASP.net 2.0:系统优化
    第一个简单的MVC页面
    用户体验时代到来,功能不再重要
    关于SQL递归优化
    web(2)
  • 原文地址:https://www.cnblogs.com/liuzhen123/p/8064814.html
Copyright © 2011-2022 走看看