欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    2022年实验六存储过程和触发器.pdf

    • 资源ID:14741310       资源大小:703.62KB        全文页数:9页
    • 资源格式: PDF        下载积分:4.3金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要4.3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    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 页 - - - - - - - - - -

    注意事项

    本文(2022年实验六存储过程和触发器.pdf)为本站会员(C****o)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开