2021HFUT数据库实验十 触发器的创建与使用

一、实验目的
本实验的目的是使学生进一步掌握 SQL Server 触发器的创建及使用方法,加深 SQL 触发器的理解。通过对数据的更新操作体会其触发器的作用。

二、实验准备
结合课堂教学内容,了解触发器的相关知识,掌握触发器的定义,理解触发器的使用方法及其特点。

三、实验要求

  1. 掌握 T-SQL 创建触发器语句 Create trigger 的使用;
  2. 完成所规定的触发器定义要求;
  3. 通过数据查询检查触发器的使用效果;
  4. 注意操作结果的截图与保存,供撰写实验报告使用。

四、实验内容

  1. 在班级表 class 中增加班级人数(c_total)字段;
  2. 为学生表(student)创建 INSERT 触发器 t_inst_stu:新增一名学生时,若其班级编号非空,则将班级表(class)中相应班级的人数(c_total)自动加 1;
  3. 为学生表(student)创建 DELETE 触发器 t_dele_stu:删除一名学生时,若其班级编号非空,则将班级表(class)中相应班级的人数(c_total)自动减 1;
  4. 为学生表(student)创建 UPDATE 触发器 t_update_stu: 当某学生所在班号发生变化时(即调到另一班级后),将其原先所在班级的人数(c_total)减 1,将新调入的班级班级的人数(c_total)加 1;
  5. 体会触发器的作用。

五、实验步骤

--在班级表 class 中增加班级人数(c_total)字段
alter table class add c_total int;

--为学生表(student)创建 INSERT 触发器 t_inst_stu:新增一名学生时,若其班级编号非空,则将班级表(class)中相应班级的人数(c_total)自动加 1
create trigger t_inst_stu on student
for insert
as begin
if exists(select * from inserted where ClsNO is not null)
begin
  update class
  set c_total=c_total+1
  where ClsNO=(select ClsNO from inserted);
end
end

--为学生表(student)创建 DELETE 触发器 t_dele_stu:删除一名学生时,若其班级编号非空,则将班级表(class)中相应班级的人数(c_total)自动减 1
create trigger t_dele_stu on student
for delete
as begin
if exists(select * from deleted where ClsNO is not null)
begin
  update class
  set c_total=c_total-1
  where ClsNO=(select ClsNO from deleted);
end
end

--为学生表(student)创建 UPDATE 触发器 t_update_stu: 当某学生所在班号发生变化时(即调到另一班级后),将其原先所在班级的人数(c_total)减 1,将新调入的班级的人数(c_total)加 1
create trigger t_update_stu on student
for update
as begin
 if exists(select * from deleted where ClsNO is not null)
 begin
   update class
   set c_total=c_total-1
   where ClsNO=(select ClsNO from deleted);
 end
 else
  if exists(select * from inserted where ClsNO is not null)
  begin
    update class
    set c_total=c_total+1
    where ClsNO=(select ClsNO from inserted);
  end
end

--体会触发器的作用
  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值