实验七 存储过程及应用完整版含截图.pdf

实验七 存储过程及应用完整版含截图.pdf

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验七 存储过程及应用 1.实验目的 1、 理解存储过程的概念。 2、掌握存储过程的使用方法。 2.实验要求 1.建立如下的存储过程 (基于前面实验建立的表和插入的数据,并为每个存 储过程设计返回的状态值): (1)按要求设计完成如下功能的存储过程。 ①查询平均分数在x 到y 范围内的学生信息。 说明: 该存储过程有两个参数; 要求查询的学生信息包括学号、姓名、院系名称和平均分数。 ②更新操作,以学号、课程编号和考试成绩作参数更新指定学生和课程的考试 成绩,并返回该学生的平均成绩。 (2)自行再分别设计一个完成查询和完成操作功能的存储过程 (在实验报告 中 要准确描述功能需求)。 (3)在客户端以存储过程和输入SQL 语句的方式分别执行相同的查询或操作, 比较使用和不使用存储过程的区别。 3、实验过程 (1)①查询平均分数在x 到y 范围内的学生信息 create procedure cc711 @x smallint,@y smallint as select 学生.学号 ,学生.姓名 ,院系.名称 ,学生.平均成绩 from 学生 join 院系 on 学生.院系 =院系.编号 where 学生.平均成绩 between@x and @y EXECUTE cc711 60,90 ②更新操作,以学号、课程编号和考试成绩作参数更新指定学生和课程的考试 成绩,并返回该学生的平均成绩 create procedure mcc712 @xh nchar(8),@kcbh nchar(8),@cj int as update 选课 set 成绩=@cj where 学号=@xh and 课程编号=@kcbh declare @pjcj int select @pjcj=AVG (成绩) from 选课 where 学号=@xh return@pjcj declare @avg int execute @avg=mcc712 2,5,98 print更新后平均成绩:+str(@avg,6) (2) 自行再分别设计一个完成查询和完成操作功能的存储过程 (在实验报告中 要准确描述功能需求)。 create procedure dcc721@kcmc nchar(20) as declare @cc721 nchar(10) select @cc721= 学生.平均成绩 from 学生 join 选课 on 学生.学号=选课.学号 where 选课.成绩 in ( select MAX(成绩) from 选课 where 选课.课程编号 in( select 课程编号 from 课程 where 学时=@kcmc)) return@cc721 declare @acc721 nchar(10) execute @acc721= dcc72116 print 最高分者的平均成绩+str(@acc721) (3)在客户端以存储过程和输入SQL 语句的方式分别执行相同的查询或操作, 比较使用和不使用存储过程的区别。 存储: create procedure cc731 @kcmc nchar(20) as select 学生.学号,姓名,性别 from 学生 join 选课 on 学生.学号=选课.学号 where 选课.课程编号 in ( select 课程编号 from 课程 where 课程名称=@kcmc) execute cc731 数据库 输入SQL 语句: select 学生.学号,姓名,性别 from 学生 join 选课 on 学生.学号=选课.学号 where 选课.课程编号 in ( select 课程编号 from 课程 where 课程名称=数据库) 4、实验总结 存储过程比SQL 的优势在于一次编译多次使用,因为在存储过程中的SQL 语 句是已经过了语法检查和编译的,可以直接执行;而SQL 总要先进行语法解析和 编译才能执行。 另外对于网络执行的话,执行相同的任务,客户端调用存储过程的代码传输量 和直接执行SQL 语句相比也要更少。 存储中参数的使用很重要,也容易出错

文档评论(0)

cjp823 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:7060131150000004

1亿VIP精品文档

相关文档