2022年实验六存储过程和触发器.pdf
实验六存储过程和触发器实验六存储过程与触发器一、目的与要求1. 掌握编写数据库存储过程的方法。2. 掌握建立数据库触发器的方法, 通过实验观察触发器的作用与触发条件设置等相关操作。二、实验准备1. 了解编写存储过程与调用的T-SQL语法; 2. 了解触发器的作用 ; 3. 了解编写触发器的 T-SQL语法。三、实验内容(一)存储过程在 studentdb数据库中建立存储过程getPractice, 查询指定院系 (名称)(作为存储过程的输入参数 )中参与“实践”课程学习的所有学生学号、姓名、所学课程编号与课程名称 ,若院系不存在 ,返回提示信息。提示:D_Info 表中存储了院系代码D_ID,而 St_Info 表中学号字段 St_ID 的前两位与之对应 ,则 D_Info 表与 St_Info 表之间的联系通过这两个字段的运算构成连接条件。1. 分别执行存储过程getPractice, 查询“法学院”与“材料科学与工程学院”的学生中参与“实践”课程的所有学生学号、姓名、所学课程编号与课程名称。create procedure getPractice D_Name varchar(30) output as begin if not exists (select * from D_Info where D_Name= D_Name ) print 对不起 ,该院系不存在 else select st_info、St_ID,C_Info、C_No,C_Name from s_c_info inner join st_info on st_info、St_ID=s_c_info、st_id inner join C_Info on s_c_info、c_no=C_Info、C_No where st_info、St_ID in ( select St_ID from st_info join D_Info on D_Info 、D_ID =left(st_info 、St_ID,2) where C_Info、C_Type=实践 and D_Info、D_Name= D_Name ) end go 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 1 页,共 9 页 - - - - - - - - - - 实验六存储过程和触发器精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 2 页,共 9 页 - - - - - - - - - - 实验六存储过程和触发器2. 利用系统存储过程sp_rename将 getPractice更名为 getPctStu execute sp_rename getPractice , getPctStu 3. 修改存储过程 getPctStu, 返回指定院系中参与实践课程的学生人次数,并利用该存储过程以“法学院”为输入参数验证执行的结果alter procedure getPctStu D_Name varchar(30) as begin if not exists (select * from D_Info where D_Name= D_Name ) print 对不起 ,该院系不存在 else select st_info、St_ID,C_Info、C_No,C_Name,count (st_info 、St_ID) as 人次数from s_c_info inner join st_info on st_info、St_ID=s_c_info、st_id inner join C_Info on s_c_info、c_no=C_Info、C_No where st_info、St_ID in ( select St_ID from st_info join D_Info on D_Info 、D_ID =left(st_info 、St_ID,2) where C_Info、C_Type=实践 and D_Info、D_Name= D_Name ) group by st_info、St_ID,C_Info 、C_No,C_Name end Go exec getPctStu 法学院 Go 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 3 页,共 9 页 - - - - - - - - - - 实验六存储过程和触发器4. 再修改存储过程 getPctStu, 返回指定院系中参与实践课程的学生人数。注:“人数”与“人次数”就是不同的,对某一学生而言 ,如果参与了多门实践课程,则“人次数”就是指其参与的课程门数,而“人数”仍为 1。(二)触发器1、在 studentdb数据库中建立一个具有审计功能的触发器: 触发器名为 tr_sc,功能要求 :审计在 s_c_info 表中对 score字段的更新与插入操作,将这些操作记录到sc_log 表中,sc_log 表中有如下字段 :操作类型 type,学号st_id,课程号 c_no,旧成绩 oldscore,新成绩 newscore, 操作员 uname, 操作时间 udate,其中操作员设定默认值为user,操作时间默认值为系统时间。create table sc_log (type varchar(4), st_id varchar(10), c_no varchar(10), oldscore int, newscore int, uname varchar(10) default user, 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 4 页,共 9 页 - - - - - - - - - - 实验六存储过程和触发器udata datetime default getdate() ) go create trigger tr_sc on s_c_info for insert,update as if update(score) begin if(select count(*) from deleted)0 insert into sc_log(type,st_id,c_no,oldscore,newscore) select update,s_c_info 、st_id,s_c_info、c_no,i、score,d 、score from s_c_info,inserted i,deleted d 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 5 页,共 9 页 - - - - - - - - - - 实验六存储过程和触发器where s_c_info、st_id=i、st_id and i、st_id=d、st_id else insert into sc_log(type,st_id,c_no,newscore) select insert,st_id,c_no,score from inserted end go 3.在 s_c_info 表上建立一个触发器tr_updasc, 用于监控对成绩的更新 ,要求更新后的成绩不能比更新前低,如果新成绩低则取消操作,给出提示信息 ,否则允许更新。create trigger tr_updasc on s_c_info after update as declare cj1 int,cj2 int select cj1=deleted 、score from deleted select cj2=inserted 、score from inserted if(cj2cj1) begin raiserror(新成绩比老成绩低 ,取消操作 ,16,1) 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 6 页,共 9 页 - - - - - - - - - - 实验六存储过程和触发器rollback transaction end go (三)查瞧存储过程与触发器的信息1、用 sp_help查瞧以上建立的存储过程与触发器的基本信息sp_help tr_sc go 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 7 页,共 9 页 - - - - - - - - - - 实验六存储过程和触发器sp_help tr_updasc go 2、用 sp_helptext查瞧存储过程与触发器的代码sp_helptext tr_sc go 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 8 页,共 9 页 - - - - - - - - - - 实验六存储过程和触发器sp_helptext tr_updasc go 四、思考与练习1.存储过程如何加密?Create procedure encrypt_this With encryption -加密,在存储过程添加这一语句即可AS Select* from user_tb GO 查瞧存储过程储存的文本: Exec sp_helptext encrypt_this 下面就是结果集 : The projects comments have been encrypted、 -对象已经被加密2.触发器有什么好处与坏处?使用触发器的好处 : 1、 自动执行。触发器在对表的数据作了任何修改(比如手工输入或者应用程序的操作 )之后立即被激活。2、 级联更新。触发器可以通过数据库中的相关表进行层叠更改,这比直接把代码写在前台的做法更安全合理。3、 强化约束。触发器可以引用其它表中的列,能够实现比 CHECK约束更为复杂的约束。4、 跟踪变化。触发器可以阻止数据库中未经许可的指定更新与变化。5、 强制业务逻辑。触发器可用于执行管理任务,并强制影响数据库的复杂业务规则。相对于外部程序、存储过程,触发器可以更快更高效地维护数据。滥用数据库的坏处 : 滥用会造成数据库及应用程序的维护困难。一个大型应用里,触发器越少越好 ,触发器会使编程时源码的结构被迫打乱,为将来的程序修改、源码阅读带来很大不便。精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 9 页,共 9 页 - - - - - - - - - -