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

  • 相关阅读:
    如果你正在找工作,也许这七个方法会帮到你
    WebSocket 浅析
    关系数据库涉及中的范式与反范式
    MySQL字段类型与合理的选择字段类型
    ER图,数据建模与数据字典
    详解慢查询
    MySQL的最佳索引攻略
    后端技术演进
    MySQL主从复制(BinaryLog)
    MySQL读写分离
  • 原文地址:https://www.cnblogs.com/liuzhen123/p/8064814.html
Copyright © 2011-2022 走看看