- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
例 14-1
创建存储过程“增加成绩”,将表“学生”中所有学生的入学成绩增加10%。
USE 学生管理
GO
CREATE PROCEDURE 增加成绩
AS
UPDATE 学生 SET 入学成绩 = 入学成绩 + 10
GO
例 14-2
在创建一个存储过程时,如果已经存在同名的存储过程,则不允许创建新的存储过程。可以将以上代码改写为:
USE 学生管理
--如果存在名称为“增加成绩”的存储过程,则将其删除
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 增加成绩 AND type = P)
DROP PROCEDURE 增加成绩
GO
CREATE PROCEDURE 增加成绩
AS
UPDATE 学生 SET 入学成绩 = 入学成绩 + 10
GO
例14-3
执行存储过程“增加成绩”,并查看执行结果。
USE 学生管理
GO
EXEC 增加成绩
SELECT * FROM 学生
GO
例14-4
创建存储过程add_proc,用于计算两个参数之和并将其输出。
CREATE PROCEDURE add_proc
@num1 INT = 0,
@num2 INT = 0
AS
DECLARE @num3 INT
SET @num3 = @num1 + @num2
PRINT @num3
(该存储过程定义了两个参数@num1和@num2,它们都是输入参数,参数类型为INT,默认值为0。)
执行例14-4
不带参数执行: EXEC add_proc
运行结果为: 0
带参数执行: EXEC add_proc 13, 25
运行结果为: 38
(有时需要将存储过程中的计算结果返回到调用程序中,以便进行进一步的处理,此时就需要在存储过程中使用输出参数。 )
例14-5
创建存储过程add_proc1,用于计算两个参数之和,并使用输出参数返回结果。
CREATE PROCEDURE add_proc1
@num1 INT = 0,
@num2 INT = 0,
@num3 INT OUTPUT --@num3为输出参数
AS
SET @num3 = @num1 + @num2
执行例14-5
DECLARE @num AS INT
EXEC add_proc1 12, 23, @num OUTPUT
PRINT @num
运行结果为:
38
例14-6
创建存储过程AvgScore,用于根据给定的院系和班级名称计算平均成绩,并使用输出参数返回结果。
CREATE PROCEDURE AvgScore
@org varchar(100), --院系名称,输入参数
@class varchar(50), --班级名称,输入参数
@score float OUTPUT -- 成绩,输出参数
AS
DECLARE @orgid int
SET @orgid = 0
-- 根据参数中指定的院系名称org, 获取院系编号
SELECT @orgid = 记录编号
FROM 院系 WHERE 院系名称=@org
IF @orgid = 0
BEGIN
SET @score = 0
PRINT 指定的院系记录不存在
END
ELSE
BEGIN
SELECT @score = AVG(入学成绩) FROM 学生
WHERE 所属院系=@orgid AND 班级=@class
GROUP BY 所属院系, 班级
END
执行例14-6
DECLARE @score float
EXEC AvgScore 软件系, 二班, @score OUTPUT
PRINT @score
运行结果为:584
例14-7
创建存储过程AvgScore1,根据给定的院系和班级名称计算平均成绩,并将结果使用输出参数返回。如果指定的院系存在,则返回1,否则返回0。
CREATE PROCEDURE AvgScore1
@org varchar(100),
@class varchar(50),
@sco
您可能关注的文档
- 涵洞工程施工方案(盖板涵.箱涵.拱涵).doc
- 合肥冰箱发泡机黑白料储罐增加体外循环技术协议.doc
- 河海大学.周三多管理学名词解释与简答.doc
- 黑龙江省牡丹江一中2011-2012学年高二下学期期末考试.数学理.doc
- 湖南省醴陵二中2010届高三上学期第四次月考(历史).doc
- 环境材料现状和发展趋势.doc
- 机电运输管理人员技术比武考试试题.doc
- 机械工程材料.习题.doc
- 基于.Net简单三层的房源信息系统设计和实现.doc
- 即墨市热电厂锅炉改造.doc
- 小学科学:ESP8266智能插座电路原理与动手实践研究教学研究课题报告.docx
- 《金融开放浪潮下我国多层次监管体系构建与创新研究》教学研究课题报告.docx
- 区域教育质量监测中人工智能应用的数据质量分析与优化策略教学研究课题报告.docx
- 《金融科技监管中的数据治理与合规性要求》教学研究课题报告.docx
- 《3D打印技术在航空航天领域中的多材料制造与复合材料应用》教学研究课题报告.docx
- 《绿色金融发展中的政府职能与市场机制研究》教学研究课题报告.docx
- 《植物工厂多层立体栽培光环境调控技术对植物生长发育节律的调控机制探讨》教学研究课题报告.docx
- 销售团队年度业绩总结.docx
- 银行风险管理与金融危机防范.docx
- 银行网络攻击预警与快速响应机制.docx
文档评论(0)