存储过程和触发器(实验报告) 本文关键词:触发器,存储过程,实验,报告
存储过程和触发器(实验报告) 本文简介:长沙理工大学计算机与通信工程学院实验报告课程名称数据库技术与应用实验项目名称存储过程和触发器班级学号姓名实验日期*年*月*日指导教师签字一﹑实验目的(1)掌握通过SQLServer管理平台和Transact-SQL语句Createprocedure创建存储过程的方法和步骤;(2)掌握使用Transa
存储过程和触发器(实验报告) 本文内容:
长
沙
理
工
大
学
计算机与通信工程学院
实
验
报
告
课程名称
数据库技术与应用
实验项目名称
存储过程和触发器
班级
学号
姓名
实验日期*年*月*日
指导教师签字
一﹑实验目的
(1)
掌握通过SQL
Server管理平台和Transact-SQL语句Create
procedure创建存储过程的方法和步骤;
(2)
掌握使用Transact-SQL语句execute执行存储过程的方法;
(3)
掌握通过SQL
Server管理平台和Transact-SQL语句Alter
procedure修改存储过程的方法;
(4)
掌握通过SQL
Server管理平台和Transact-SQL语句Drop
procedure删除存储过程的方法;
(5)
掌握通过SQL
Server管理平台和Transact-SQL语句Create
trigger创建触发器的方法和步骤;
(6)
掌握引发触发器的方法;
(7)
掌握使用SQL
Server管理平台或Transact-SQL语句修改和删除触发器;
(8)
掌握事务、命名事务的创建方法,了解不同类型的事务的处理情况。
二﹑实验平台
操作系统:Windows
xp
DBMS:SQL
Server
2005
三﹑实验内容和步骤
1.使用studentsdb数据库中的student_info表、curriculum表、grade表。
(1)创建一个存储过程stu_grade,查询学号为0001的学生的姓名、课程名称、分数。
(2)执行存储过程stu_grade,查询0001学生的姓名、课程名称、分数。
(3)使用系统存储过程sp_rename将存储过程stu_grade更名为stu_g。
CREATE
PROCEDURE
stu_grade
AS
SELECT
a.学号,c.课程名称,b.分数
FROM
student_info
a
INNER
JOIN
grade
b
ON
a.学号
=
b.学号
INNER
JOIN
curriculum
c
ON
b.课程编号
=
c.课程编号
WHERE
(a.学号
=
0001
)
EXEC
stu_grade
sp_rename
stu_grade,stu_g
2.使用student_info表、curriculum表、grade表。
(1)创建一个带参数的存储过程stu_g_p,当任意输入一个学生的姓名时,将从3个表中返回该学生的学号、选修的课程名称和课程成绩。
(2)执行存储过程stu_g_p,查询“刘卫平”的学号、选修课程和课程成绩。
(3)使用系统存储过程sp_helptext,查看存储过程stu_g_p的文本信息。
CREATE
PROCEDURE
stu_g_p
@stu_name
varchar(8)
AS
SELECT
a.学号,c.课程名称,b.分数
FROM
student_info
a
INNER
JOIN
grade
b
ON
a.学号
=
b.学号
INNER
JOIN
curriculum
c
ON
b.课程编号
=
c.课程编号
WHERE
(a.姓名
=
@stu_name)
EXEC
stu_g_p
‘刘卫平’
sp_helptext
stu_g_p
3.使用student_info表。
(1)创建一个加密的存储过程stu_en,查询所有男学生的信息。
(2)执行存储过程stu_en,查看返回学生的情况。
(3)使用Transact-SQL语句DROP
PROCEDURE删除存储过程stu_en。
CREATE
PROCEDURE
stu_en
WITH
ENCRYPTION
AS
SELECT
FROM
student_info
WHERE
性别=
男
EXEC
stu_en
DROP
PROCEDURE
stu_en
4.使用grade表。
(1)创建一个存储过程stu_g_r,当输入一个学生的学号时,通过返回输出参数获取该学生各门课程的平均成绩。
CREATE
PROC
stu_g_r
@stu_no
varchar(8)=NULL,@stu_score
real
OUTPUT
AS
SELECT
@stu_score
=AVG(分数)
FROM
grade
WHERE
(学号
[email protected]_no)
(2)执行存储过程stu_g_r,输入学号0002。
DECLARE
@score
real
EXEC
stu_g_r
0002,@score
OUTPUT
(3)显示0002号学生的平均成绩。
SELECT
@score
5.为grade表建立一个名为insert_g_tr
的INSERT触发器,当用户向grade表中插入记录时,如果插入的是在curriculum表中没有的课程编号,则提示用户不能插入记录,否则提示记录插入成功。在进行插入测试时,分别输入以下数据:
学号
课程编号
分数
0004
0003
76
0005
0007
69
观察插入数据时的运行情况,说明为什么?
CREATE
TIGGER
insert_g_tr
ON
grade
FOR
UPDATE,INSERT
AS
DECLARE
@fkc_id
varchar(8)
SET
@fkc_id=(SELECT
课程编号
FROM
INSERTED)
IF
EXISTS(SELECT
1
FROM
curriculum
WHERE
课程编号[email protected]_id)
BEGIN
‘记录插入成功’
END
ELSE
BEGIN
RAISERROR(‘无此课程,不能插入记录’,16,1)
END
6.为curriculum表创建一个名为del_c_tr的DELETE触发器,该触发器的作用是禁止删除curriculum表中的记录。
CREATE
TRIGGER
del_c_tr
ON
curriculum
AS
RAISERROR(‘禁止删除curriculum表中的记录’)
ROLLBACK
TRANSACTION
7.为student_info表创建一个名为update_s_tr的UPDATE触发器,该触发器的作用是禁止更新student_info表中的“姓名”字段的内容。
CREATE
TIGGER
update_s_tr
ON
student_info
FOR
UPDATE
AS
DECLARE
@name_old
varchar(8)
DECLARE
@name_new
varchar(8)
SET
@name_old=(SELECT
姓名
FROM
Deleted)
SET
@name_new=(SELECT
姓名
FROM
Inserted)
IF
(@[email protected]_new)
BEGIN
RAISERROR(‘不能修改姓名’,16,1)
END
8.使用Transact-SQL语句DROP
TRIGGER删除update_s_tr触发器。
DROP
TRIGGER称update_s_tr
9.为student_info表建立删除触发器del_s_tr,要求当student_info表的记录被删除后,grade表中相应的记录也能自动删除。
CREATE
TIGGER
del_s_tr
ON
student_info
FOR
DELETE
AS
DECLARE
@stu_no
varchar(8)
SET
@stu_no=(SELECT
学号
FROM
Deleted)
DELETE
FROM
grade
WHERE
学号[email protected]_no
四﹑命令(代码)清单
五﹑调试和测试清单
六﹑教师批语与成绩评定