实验七 数据库实验

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验七触发器

一、实验目的

(1)理解触发器的用途、类型和工作原理

(2)掌握利用T-SQL语句创建和维护触发器的方法

(3)掌握利用企业管理器创建、维护触发器的方法

二、实验内容

1.创建after触发器

(1)创建一个在插入时触发的触发器sc_insert,当向sc表插入数据时,须确保插入的学号已在Student表中存在,并且还须确保保插入的课程号在Course表中存在;若不存在,则给出相应的提示信息,并取消插入操作,提示信息要求指明插入信息是学号不满足条件还是课程号不满足条件(注:Student表与sc表的外键约束要先取消)。

USE[Student_info_20103277]

GO

/****** Object: Trigger [dbo].[sc_insert] Script Date: 11/27/2012 15:41:37 ******/

SET ANSI_NULLS ON

GO

SET QUOTED_IDENTIFIER ON

GO

ALTER trigger[dbo].[sc_insert]

on[dbo].[SC_20103277]

after insert

as

declare@mSno char(8),

@mCno char(3)

select@mSno=Sno,@mCno=Cno

from inserted

if@mSno!=

(select Sno

from Student_20103277

where Sno=@mSno)

begin

rollback tran

print('学号不存在!')

end

if@mCno!=

(select Cno

from Course_20103277

where Cno=@mCno)

begin

rollback tran

print('课程号不存在!')

end

else

print'插入成功!'

先删除主键约束。

insert

into SC_20103277(Sno,Cno,Grade) values('20110001','001','99')

insert

into SC_20103277(Sno,Cno,Grade)

values('20110001','111','99')

insert

into SC_20103277(Sno,Cno,Grade)

values('20110011','111','99')

(2)为Course表创建一个触发器Course_del,当删除了Course表中的一条课程信息时,同时将表sc表中相应的学生选课记录删除掉。

create trigger Course_del

on Course_20103277

after delete

as

begin

declare@mCno char(3)

select@mCno=Cno

from deleted

delete

from SC_20103277

where Cno=@mCno

end

delete

from Course_20103277

where Cno='004'

(3)在Course表中添加一个平均成绩avg_Grade字段(记录每门课程的平均成绩),创建一个触发器Grade_modify,当SC表中的某学生的成绩发生变化时,则Course表中的平均成绩也能及时相应的发生改变。

alter table Course_20103277

add avg_Grade int

if exists

(select name

from sysobjects

where name='Grade_modify'and

type='tr')

drop trigger Grade_modify

go

create trigger Grade_modify

on SC_20103277

for update

as

update Course_20103277

set avg_Grade=

(select avg(Grade)

from SC_20103277

where SC_o=Course_o)

update SC_20103277

set Grade='88'

where Sno='20100001'and

Cno='001'

(4)测试上述三个触发器。

2.创建instead of 触发器

(1)创建一视图Student_view,包含学号、姓名、课程号、课程名、成绩等属性,在Student_view上创建一个触发器Grade_moidfy,当对Student_view中的学生的成绩进行修改时,实际修改的是sc中的相应记录。

create view Student_view

as

select Student_20103277.Sno,Sname,Course_o,Cname,Grade

from Student_20103277,Course_20103277,SC_20103277

type='tr')

相关文档
最新文档