概述
一、实验目的
本实验的目的是使学生进一步掌握 SQL Server 触发器的创建及使用方法,加深 SQL 触发器的理解。通过对数据的更新操作体会其触发器的作用。
二、实验准备
结合课堂教学内容,了解触发器的相关知识,掌握触发器的定义,理解触发器的使用方法及其特点。
三、实验要求
- 掌握 T-SQL 创建触发器语句 Create trigger 的使用;
- 完成所规定的触发器定义要求;
- 通过数据查询检查触发器的使用效果;
- 注意操作结果的截图与保存,供撰写实验报告使用。
四、实验内容
- 在班级表 class 中增加班级人数(c_total)字段;
- 为学生表(student)创建 INSERT 触发器 t_inst_stu:新增一名学生时,若其班级编号非空,则将班级表(class)中相应班级的人数(c_total)自动加 1;
- 为学生表(student)创建 DELETE 触发器 t_dele_stu:删除一名学生时,若其班级编号非空,则将班级表(class)中相应班级的人数(c_total)自动减 1;
- 为学生表(student)创建 UPDATE 触发器 t_update_stu: 当某学生所在班号发生变化时(即调到另一班级后),将其原先所在班级的人数(c_total)减 1,将新调入的班级班级的人数(c_total)加 1;
- 体会触发器的作用。
五、实验步骤
--在班级表 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
--体会触发器的作用
最后
以上就是霸气水壶为你收集整理的2021HFUT数据库实验十 触发器的创建与使用的全部内容,希望文章能够帮你解决2021HFUT数据库实验十 触发器的创建与使用所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复