zoukankan      html  css  js  c++  java
  • 数据库-触发器

    -- 一、 触发器 (trigger):
    -- 定义: 当表中数据变更时(添加,删除,修改),可自动执行一段数据库逻辑语句块。
    -- 这就是触发器的功能

    -- 根据数据的变更方式不同,一种表最多可定义6个触发器
    -- 添加数据之前触发器, 添加数据之后触发器
    -- 删除数据之前触发器, 删除数据之后触发器
    -- 修改数据之前触发器,修改数据之后触发器

    -- 定义触发器语法:
    create trigger 触发器名称 after/before insert/delete/update on 表名
    for each row
    begin
    -- 触发器执行sql语句
    end;

    -- 给学生表添加记录,增加触发器,学生所在系的人数+1
    create trigger tri_add after insert on t_student
    for each row
    begin
    -- 1、 对于新增数据,触发器通过虚拟表记录获取刚刚新增的数据 new.字段名 new.did表示学生表的字段did
    update t_dept set dnumber = dnumber +1 where did = new.did;
    end;

    select * from t_dept;

    select * from t_student

    insert into t_student(sid ,sname , ssex , sage ,sclass , did , sbir , sscore , sename ,sphone ) values(1000,'李全权','男',22, 1 ,1 ,now(), 500,'li','18800009999');

    -- 2、删除触发器 需要获取刚刚删除的记录,使用old.字段名
    -- 在输出学生信息时,对应系部的人数要减1
    create trigger tri_delete after delete on t_student
    for each row
    begin
    update t_dept set dnumber = dnumber - 1 where did = old.did ;
    end

    delete from t_student where sid = 1234;

    -- 给一个学生转系
    -- 将 学生id=1000 从 外语系转到 计算机系 ,对应的外语系人数减少,计算机人数增多
    -- 3、修改触发器 update ,对于修改触发器,可以同时使用old 和 new 获取老数据和新数据

    create trigger tri_update after update on t_student
    for each row
    begin
    -- 原来系的人数减少
    update t_dept set dnumber = dnumber -1 where did = old.did;
    -- 现在系的人数增多
    update t_dept set dnumber = dnumber +1 where did = new.did ;
    end;
    -- 修改数据
    update t_student set did = 3 where sid =1000;

    select * from t_student where sid = 1000;
    select * from t_dept;

  • 相关阅读:
    P4396 [AHOI2013]作业
    NOIP2018普及T2暨洛谷P5016 龙虎斗
    NOIP2018普及T1暨洛谷P5015 标题统计 题解
    【交题大桥】团队信息存档
    markdown浅谈
    洛谷P1690 贪婪的Copy 题解
    洛谷P4994 终于结束的起点 题解
    洛谷P4995 跳跳!题解
    这么多都变了,洛谷4还会远吗?
    洛谷P1396 营救 题解
  • 原文地址:https://www.cnblogs.com/z5452830/p/14053418.html
Copyright © 2011-2022 走看看