数据库系统概论实验4——存储过程.docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据库系统概论 实验四 存储过程 (4课时) 实验目的: 理解存储过程的作用和优点。 掌握SQL Server中存储过程的定义语法。 实验方法: 由于教材上存储过程部分内容较少,且实验环境SQL Server的存储过程方面语法与教材上有差异,因此本次实验课的内容包括两部分,先由老师结合实例进行补充讲解,然后布置实验内容、给出提示,学生参照实例进行实验。 实验要求: 本次实验要求撰写实验报告,要求同前。 实验内容: 第一部分 讲解 存储过程创建语法: CREATE PROCEDURE 过程名 (参数名1 类型,参数名2 类型,……) AS DECLARE 变量名1 类型 , //变量名以@开头 …… , 变量名n 类型 BEGIN //可缺省 T-SQL语句序列 END //可缺省 一、无参数的存储过程 1.创建 create proc p1 as select * from student where ssex=女 注:创建存储过程的语句要作为一个事务单独执行 2.执行 exec p1 注:exec后不要加procedure 3.修改 alter proc p1 as select * from student where ssex=女 select * from student where ssex=男 执行并查看结果 4.删除 drop proc p1 二、使用参数的存储过程 (一)使用输入参数 1.创建(功能:查询某同学选修的课程名称和成绩,直接显示) create proc p2 (@name char(8)) as select cname,grade from student,sc,course where student.sno=sc.sno and sc.cno=course.cno and sname=@name 注:参数名以@开头,多个参数间用逗号分隔,参数表可不用()括起 2.执行 (1)按位置传递参数 exec p2 张三 (设有‘张三’这个学生名) 注:当有多个参数时顺序不能错。 (2)按参数名传递参数 exec p2 @name=张三 (二)使用输出参数返回值 调用语句要包含一个变量来接受返回值,所以要先声明一个变量。 在创建存储过程语句和调用语句中,每个输出参数都必须使用OUTPUT关键字。 1.创建(功能:查询某门课的平均成绩,作为返回值用于后续处理) create proc p3 (@cno char(4),@avgs numeric output) as select @avgs=avg(grade) from sc where cno=@cno 2.执行 declare @avg numeric exec p3 0001,@avg output (设有‘0001’这个课程号) select 平均成绩=@avg 注:此三条语句必须一起执行,否则不能识别变量@avg。 第二部分 实验 创建一个存储过程,查看‘0002’号课程的选修学生姓名和成绩,并执行。 创建一个存储过程,根据课程号查看某门课程的选修学生姓名和成绩。要求使用两种参数传递方法执行该存储过程。 创建一个存储过程,根据课程号获取选修某门课程的总人数作为返回值;执行该存储过程,显示总人数。 编写存储过程实现功能:根据课程名统计某课程的成绩分布情况,即按照各分数段统计人数。执行该存储过程,显示结果。(可采用作业提示方法,也可使用输出参数获取结果) 4.CREATE PROCEDURE statistic_mark (@name CHAR(50)) AS DECLARE @less60 INT, @b60a70 INT, @b70a80 INT, @b80a90 INT, @more90 INT, @curcno CHAR(4) BEGIN //可缺省 SELECT @curcno=cno FROM Course WHERE cname=@name; IF @curcno IS NULL begin ROLLBACK; RAISERROR (输入错误,没有该课程,16,1); END; SELECT @less60=count(*) FROM sc WHERE cno=@curcno AND grade60; SELECT @b60a70=count(*) FROM sc WHERE cno=@curcno AND grade=60

文档评论(0)

ligennv1314 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档