第5章_6存储过程讲解.ppt

  1. 1、本文档共21页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第5章_6存储过程讲解

存储过程概述 存储过程 是存储在服务器上的 Transact-SQL 语句的命名集合 是封装重复性任务的方法 支持用户声明变量、条件执行以及其他强有力的编程特性 SQL Server 中的存储过程与其他编程语言中的过程类似,它可以 包含执行数据库操作(包括调用其他过程)的编程语句 接受输入参数 向调用过程或批处理返回状态值,以表明成功或失败(以及失败原因) 以输出参数的形式将多个值返回至调用过程或批处理 存储过程的优点 存储过程封装了商务逻辑,确保一致的数据访问和修改。若规则或策略有变化,则只需要修改服务器上的存储过程,所有的客户端就可以直接使用 屏蔽数据库模式的详细资料。用户不需要访问底层的数据库和数据库内的对象 提供了安全性机制。用户可以被赋予执行存储过程的权限,而不必在存储过程引用的所有对象上都有权限 改善性能。预编译的 Transact-SQL 语句,可以根据条件决定执行哪一部分 减少网络通信量。客户端用一条语句调用存储过程,就可以完成可能需要大量语句才能完成的任务,这样减少了客户端和服务器之间的请求/回答包 举例 [例] 利用存储过程来实现下面的应用: 从一个账户转指定数额的款项到另一个账户中。 CREATE PROCEDURE TRANSFER (@inAccount INT, @outAccount INT, @amount decimal(30,5)) AS DECLARE @totalDeposit decimal(30,5); BEGIN Begin transaction /*开始转账事务*/ SELECT @totalDeposit = total /* 检查转出账户的余额 */ FROM ACCOUNT WHERE ACCOUNTNUM=@outAccount; IF @totalDeposit IS NULL /* 账户不存在或账户中没有存款 */ BEGIN ROLLBACK; RETURN; END; 举例 IF @totalDeposit @amount /* 账户账户存款不足 */ BEGIN ROLLBACK; RETURN; END; UPDATE account SET total=total-@amount WHERE ACCOUNTNUM=@outAccount; /* 修改转出账户,减去转出额 */ UPDATE account SET total=total + @amount WHERE ACCOUNTNUM=@inAccount; /* 修改转入账户,增加转出额 */ COMMIT; /* 提交转账事务 */ END; 举例 [例]从账户01003815868转一万元到01003813828账户中。 EXEC Procedure TRANSFER(01003813828,01003815868,10000); 修改和删除存储过程(续) 删除存储过程 语法:DROP PROCEDURE {存储过程名} [,...n] 用 DROP PROCEDURE 语句从当前数据库中移除用户定义存储过程 删除存储过程的注意事项 在删除存储过程之前,执行系统存储过程 sp_depends 检查是否有对象依赖于此存储过程 存储过程概述 创建和管理存储过程 在存储过程中使用参数 第5章 存储过程 在存储过程中使用参数 使用输入参数 使用输入参数执行存储过程 显式地重新编译存储过程 使用输入参数 输入参数允许传递信息到存储过程内 在 CREATE PROCEDURE 中指定 @参数名 数据类型 [=默认值] USE Northwind GO CREATE PROC dbo.OverdueOrders2 @Employee_ID int , @Order_date datetime AS SELECT Ord

文档评论(0)

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

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

1亿VIP精品文档

相关文档