ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

数据库-触发器

2020-11-28 18:01:07  阅读:210  来源: 互联网

标签:触发器 -- dnumber 数据库 update did student


-- 一、 触发器 (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;

标签:触发器,--,dnumber,数据库,update,did,student
来源: https://www.cnblogs.com/z5452830/p/14053418.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有