SQL数据库实验报告-实验六.doc
《SQL数据库实验报告-实验六.doc》由会员分享,可在线阅读,更多相关《SQL数据库实验报告-实验六.doc(8页珍藏版)》请在冰豆网上搜索。
7
第1部分Error!
Notextofspecifiedstyleindocument.
北京工业大学
数据库实验报告
存储过程和触发器
姓名:
邱健康
学号:
09521320
专业:
电信
实验8存储过程和触发器
1.实验目的
(1)掌握通过SQLServer管理平台和Transact-SQL语句CREATEPROCEDURE创建存储过程的方法和步骤。
(2)掌握使用Transact-SQL语句EXECUTE执行存储过程的方法。
(3)掌握通过SQLServer管理平台和Transact-SQL语句ALTERPROCEDURE修改存储过程的方法。
(4)掌握通过SQLServer管理平台和Transact-SQL语句DROPPROCEDURE删除存储过程的方法。
(5)掌握通过SQLServer管理平台和Transact-SQL语句CREATETRIGGER创建触发器的方法和步骤。
(6)掌握引发触发器的方法。
(7)掌握使用SQLServer管理平台或Transact-SQL语句修改和删除触发器。
2.实验内容及步骤
(1)在查询设计器中输入以下代码,创建一个利用流控制语句的存储过程letters_print,该存储过程能够显示26个小写字母。
CREATEPROCEDUREletters_print
AS
DECLARE@countint
SET@count=0
WHILE@count<26
BEGIN
PRINTCHAR(ASCII('a')+@count)
SET@count=@count+1
END
单击查询分析器的“执行查询”按钮,查看studentsdb数据库的存储过程是否有letters_print。
使用EXECUTE命令执行letters_print存储过程。
(2)输入以下代码,创建存储过程stu_info,执行时通过输入姓名,可以查询该姓名对应的学生的各科成绩。
CREATEPROCEDUREstu_info@namevarchar(40)
AS
SELECTa.学号,姓名,课程编号,分数
FROMstudent_infoaINNERJOINgradeta
ONa.学号=ta.学号
WHERE姓名=@name
使用EXECUTE命令执行存储过程stu_info,其参数值为“马东”。
(3)使用studentsdb数据库中的student_info表、curriculum表、grade表。
①创建一个存储过程stu_grade,查询学号为0001的学生的姓名、课程名称、分数。
②执行存储过程stu_grade,查询0001学生的姓名、课程名称、分数。
③使用系统存储过程sp_rename将存储过程stu_grade更名为stu_g。
(4)使用student_info表、curriculum表、grade表。
①创建一个带参数的存储过程stu_g_p,当任意输入一个学生的姓名时,将从3个表中返回该学生的学号、选修的课程名称和课程成绩。
②执行存储过程stu_g_p,查询“刘卫平”的学号、选修课程和课程成绩。
③使用系统存储过程sp_helptext,查看存储过程stu_g_p的文本信息。
(5)使用student_info表。
①创建一个加密的存储过程stu_en,查询所有男学生的信息。
②执行存储过程stu_en,查看返回学生的情况。
③使用Transact-SQL语句DROPPROCEDURE删除存储过程stu_en。
(6)使用grade表。
①创建一个存储过程stu_g_r,当输入一个学生的学号时,通过返回输出参数获取该学生各门课程的平均成绩。
②执行存储过程stu_g_r,输入学号0002。
③显示0002号学生的平均成绩。
(7)输入以下代码,复制student_info表命名为stu2,为stu2表创建一个触发器stu_tr,当stu2表插入一条记录时,为该记录生成一个学号,该学号为学号列数据的最大值加1。
--复制student_info表命名为stu2
SELECT*INTOstu2FROMstudent_info
GO
--为stu2表创建一个INSERT型触发器stu_tr
CREATETRIGGERstu_tr
ONstu2FORINSERT
AS
DECLARE@maxchar(4)
SET@max=(SELECTMAX(学号)FROMstu2)
SET@max=@max+1
UPDATEstu2SET学号=REPLICATE('0',4-len(@max))+@max
FROMstu2INNERJOINinsertedonstu2.学号=inserted.学号
执行以上代码,查看studentsdb数据库中是否有stu2表,展开stu2,查看其触发器项中是否有stu_str触发器。
在查询设计器的编辑窗口输入以下代码:
INSERTINTOstu2(学号,姓名,性别)VALUES('0001','张主','女')
运行以上代码,查看stu2表的变化情况,为什么插入记录的学号值发生了改变?
答:
因为触发器中,设置要插入的学号为已插入数据中最大学号值+1,一旦插入就执行.
(8)为grade表建立一个名为insert_g_tr的INSERT触发器,当用户向grade表中插入记录时,如果插入的是在curriculum表中没有的课程编号,则提示用户不能插入记录,否则提示记录插入成功。
在进行插入测试时,分别输入以下数据:
学号课程编号分数
0004000376
0005000769
观察插入数据时的运行情况,说明为什么?
答:
因为触发器规定若curriculum表中没有要插入的课程编号,则不允许插入,并回滚.
(9)为curriculum表创建一个名为del_c_tr的DELETE触发器,该触发器的作用是禁止删除curriculum表中的记录。
(10)为student_info表创建一个名为update_s_tr的UPDATE触发器,该触发器的作用是禁止更新student_info表中的“姓名”字段的内容。
(11)使用Transact-SQL语句DROPTRIGGER删除update_s_tr触发器。
3.实验思考
(1)用系统存储过程sp_helptext查看系统存储过程是怎么编写出来的。
USEAdventureWorks2012;
GO
SELECT
OBJECT_DEFINITION(OBJECT_ID(N'AdventureWorks2012.dbo.uspLogError'));
调用时会找到对应的对象ID,来查看系统存储过程.
(2)用系统存储过程sp_helptrigger查看前面各触发器的类型。
答:
sp_helptrigger'table''type';