- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
最近下载
- 腹腔引流管脱管应急预案.pptx VIP
- 呼吸衰竭最新治疗指南解读PPT课件.pptx VIP
- 呼吸衰竭最新治疗指南解读PPT课件.pptx VIP
- 辟谷养身:12.空腹力革命.pdf VIP
- 施工组织设计主要经济指标.pptx VIP
- 2023年ISO15189 医学实验室管理体系全套表格.docx VIP
- DLT5210-2021版第一部分土建工程(热力系统土建工程质量验收)可编辑表格.docx VIP
- 10000字在学校挨机器人板子的作文.docx VIP
- 《A水利枢纽的拱坝设计中拱坝应力分析计算案例》3000字.docx VIP
- 2025年河北承德市中小学教师招聘考试试卷带答案.docx VIP
文档评论(0)