7实验七 触发器.
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验七触发器
一、实验目的
(1)理解触发器的用途、类型和工作原理
(2)掌握利用T-SQL语句创建和维护触发器的方法
(3)掌握利用企业管理器创建、维护触发器的方法
二、实验内容
1.创建after触发器
(1)创建一个在插入时触发的触发器sc_insert,当向sc表插入数据时,须确保插入的学号已在Student表中存在,并且还须确保插入的课程号在Course表中存在;若不存在,则给出相应的提示信息,并取消插入操作,提示信息要求指明插入信息是学号不满足条件还是课程号不满足条件(注:Student表与sc表的外键约束要先取消)。
create trigger sc_insert
on sc
after insert
as
if not exists(select*from student,inserted
where student.sno=inserted.sno)
begin
print'插入信息的学号不在学生表中!'
if not exists(select*from course,inserted where
o=o)
print'插入信息的课程号不在课程表中!'
rollback
end
else
begin
if not exists(select*from course,inserted where
o=o)
begin
print'插入信息的课程号不在课程表中!'
rollback
end
end
执行:
①、insert into SC
values('20110112','001','78')
删除外键约束:
alter table SC
drop constraint FK__SC__Sno__182C9B23
②、insert into SC
values('20110002','001','78')
③、insert into SC
values('20110002','006','78')
(2)为Course表创建一个触发器Course_del,当删除了Course表中的一条课程信息时,同时将表sc表中相应的学生选课记录删除掉。
create trigger course_del
on course
after delete
as
if exists(select*from sc,deleted
where o=o)
begin
delete from sc
where o in(select cno from deleted)
end
delete from Course
where Cno='003'
select*from SC
(3)在Course表中添加一个平均成绩avg_Grade字段(记录每门课程的平均成绩),创建一个触发器Grade_modify,当SC表中的某学生的成绩发生变化时,则Course表中的平均成绩也能及时相应的发生改变。
alter table Course
add avg_Grade smallint
update Course
set avg_Grade=(select AVG(Grade)from SC
where o=o)
select*from Course
create trigger Grade_modify
on sc
after update
as
if update(grade)
begin
update course
set avg_grade=(select avg(grade)
from sc where o=o
group by cno)
end
update SC
set Grade='90'
where Sno='20050001'and Cno='001'
(4)测试上述三个触发器。
测试过程在(1)、(2)、(3)中均给出
2.创建instead of 触发器
(1)创建一视图Student_view,包含学号、姓名、课程号、课程名、成绩等属性,在Student_view上创建一个触发器Grade_moidfy,当对Student_view中的学生的成绩进行修改时,实际修改的是sc中的相应记录。
create view Student_view
as
select s.Sno,Sname,o,Cname,Grade
from Student s,Course c,SC
where s.Sno=SC.Sno and o=o
select*from Student_view
create trigger Grade_moidfy
on Student_view
instead of update
as
if UPDATE(Grade)
begin
update SC
set Grade=(select Grade from inserted)where Sno=(select Sno from inserted)and
Cno=(select Cno from inserted)
end
update Student_view
set Grade=40
where Sno='20110001'and Cno='002'
select*from Student_view