- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据库系统原理及应用 SQLServer2000编程--存储过程 存储过程 1 存储过程的基本知识 1. 概念 存储过程(Stored Procedure) 是存储在服务器上的 Transact-SQL 语句的命名集合 是封装重复性任务的方法 支持用户声明变量、条件执行以及其他强有力的编程特性 2.功能 存储过程与其他编程语言中的过程类似,它可以 包含执行数据库操作(包括调用其他过程)的编程语句 接受输入参数 向调用过程或批处理返回状态值,以表明成功或失败(以及失败原因) 以输出参数的形式将多个值返回至调用过程或批处理 1 存储过程的基本知识 3. 优点 使用存储过程而不使用存储在客户端计算机本地的 T-SQL 程序的优点包括: 与其他应用程序共享应用逻辑,确保一致的数据访问和修改。存储过程封装了商务逻辑。若规则或策略有变化,则只需要修改服务器上的存储过程,所有的客户端就可以直接使用 能够实现较快的执行速度预编译的 Transact-SQL 语句,可以根据条件决定执行哪一部分 能够减少网络流量客户端用一条语句调用存储过程,就可以完成可能需要大量语句才能完成的任务,这样减少了客户端和服务器之间的请求/回答包 提供了安全性机制。屏蔽数据库模式的详细资料。用户不需要访问底层的数据库和数据库内的对象。用户可以被赋予执行存储过程的权限,而不必在存储过程引用的所有对象上都有权限 1存储过程的基本知识 4 分类 SQL Server 支持五种类型的存储过程 系统存储过程(sp_):存储在 master 数据库内,以“sp_”前缀标识 本地存储过程:本地存储过程在单独的用户数据库内创建 临时存储过程:临时存储过程可能是局部的,名称以“#”开头;也可能是全局的,名称以“##”开头 远程存储过程:远程存储过程是 SQL Server 早期版本的特性,分布式查询支持这项功能 扩展存储过程(xp_):扩展存储过程以动态链接库(DLL)的形式实现,在 SQL Server 环境外执行 存储过程的初始处理 存储过程的处理 包括创建,以及初次执行时将执行计划放入过程缓存 过程缓存是一个包含所有当前正在执行的Transact-SQL 语句的执行计划的内存池,其大小动态变化 过程缓存在内存池内。内存池是 SQL Server 内存的主要单元,它包含了 SQL Server 中大部分使用内存的数据结构 存储过程的初始处理 存储过程的创建 创建存储过程时,先分析该过程中的语句以检查语法的准确性。然后 SQL Server 将存储过程的名字存入当前数据库的 sysobjects 系统表中,存储过程的文本存入当前数据库的 syscomments 系统表中 延迟名称解析:存储过程引用的对象不需要在创建该存储过程时就存在,而只需在执行该存储过程时存在 存储过程的执行(初次或重新编译时) 存储过程初次执行或者重新编译后,查询处理器读入存储过程的处理过程称为解析 数据库的某些变化会使得执行计划低效或失效,SQL Server 检测这些变化并自动重新编译执行计划 存储过程的初始处理 优化 如果过程执行顺利通过解析阶段,则查询优化器将分析该存储过程中的 Transact-SQL 语句,并创建一个执行计划,描述执行存储过程的最快方法 编译 编译指的是分析存储过程,创建执行计划并将之放入过程缓存的过程 过程缓存包含了最有价值的存储过程执行计划。增加执行计划价值的因素包括:重新编译需要的时间(高的编译代价)和频繁被使用 存储过程的初始处理 存储过程的后续处理 若符合下列条件,则 SQL Server 使用在内存中的计划来执行随后的查询 当前的环境和计划编译时的环境相同。服务器、数据库和连接的设置决定了环境 存储过程引用的对象不需要名称解析。若被不同用户拥有的对象具有相同的名字,则需要名称解析 SQL Server 的执行计划有两个主要部分 查询计划:执行计划的主体是一个重入的只读数据结构,可由任意数量的用户使用,这称为查询计划。查询计划中不存储用户环境 执行环境:每个正在执行查询的用户都有一个包含其执行专用数据(如参数值)的数据结构,称为执行环境 存储过程的后续处理 在缓存中,对于每个存储过程和环境的组合最多只有一个编译过的计划。对于一个存储过程的多个不同环境,可以有多个计划 形成不同环境并影响编译选择的因素 并行和串行编译计划 隐含的对象拥有 不同的 SET 选项 一个执行计划产生后,驻留在过程缓存中。仅当需要空间时,SQL Server 将老的、没用的计划移出缓存 存储过程的后续处理 3 创建存储过程 既可创建一个存储过程供永久使用,也可创建一个存储过程在一个会话中临时使用(局部临时过程),或在所有会话中临时使用(全局临时过程)。语法格式为: Create Pro
文档评论(0)