数据库系统原理及应用-存储过程

数据库系统原理及应用-存储过程

ID:42067913

大小:1.20 MB

页数:63页

时间:2019-09-07

数据库系统原理及应用-存储过程_第1页
数据库系统原理及应用-存储过程_第2页
数据库系统原理及应用-存储过程_第3页
数据库系统原理及应用-存储过程_第4页
数据库系统原理及应用-存储过程_第5页
资源描述:

《数据库系统原理及应用-存储过程》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、数据库系统原理及应用SQLServer2000编程--存储过程存储过程第一步第二步第三步存储过程的基本知识创建用户存储过程存储过程的参数21存储过程的基本知识1.概念存储过程(StoredProcedure)是存储在服务器上的Transact-SQL语句的命名集合是封装重复性任务的方法支持用户声明变量、条件执行以及其他强有力的编程特性2.功能存储过程与其他编程语言中的过程类似,它可以包含执行数据库操作(包括调用其他过程)的编程语句接受输入参数向调用过程或批处理返回状态值,以表明成功或失败(以及失败原

2、因)以输出参数的形式将多个值返回至调用过程或批处理31存储过程的基本知识3.优点使用存储过程而不使用存储在客户端计算机本地的T-SQL程序的优点包括:与其他应用程序共享应用逻辑,确保一致的数据访问和修改。存储过程封装了商务逻辑。若规则或策略有变化,则只需要修改服务器上的存储过程,所有的客户端就可以直接使用能够实现较快的执行速度预编译的Transact-SQL语句,可以根据条件决定执行哪一部分能够减少网络流量客户端用一条语句调用存储过程,就可以完成可能需要大量语句才能完成的任务,这样减少了客户端和服务

3、器之间的请求/回答包提供了安全性机制。屏蔽数据库模式的详细资料。用户不需要访问底层的数据库和数据库内的对象。用户可以被赋予执行存储过程的权限,而不必在存储过程引用的所有对象上都有权限41存储过程的基本知识4分类SQLServer支持五种类型的存储过程系统存储过程(sp_):存储在master数据库内,以“sp_”前缀标识本地存储过程:本地存储过程在单独的用户数据库内创建临时存储过程:临时存储过程可能是局部的,名称以“#”开头;也可能是全局的,名称以“##”开头远程存储过程:远程存储过程是SQLSer

4、ver早期版本的特性,分布式查询支持这项功能扩展存储过程(xp_):扩展存储过程以动态链接库(DLL)的形式实现,在SQLServer环境外执行5存储过程的初始处理存储过程的处理包括创建,以及初次执行时将执行计划放入过程缓存过程缓存是一个包含所有当前正在执行的Transact-SQL语句的执行计划的内存池,其大小动态变化过程缓存在内存池内。内存池是SQLServer内存的主要单元,它包含了SQLServer中大部分使用内存的数据结构6存储过程的初始处理存储过程的创建创建存储过程时,先分析该过程中的语

5、句以检查语法的准确性。然后SQLServer将存储过程的名字存入当前数据库的sysobjects系统表中,存储过程的文本存入当前数据库的syscomments系统表中延迟名称解析:存储过程引用的对象不需要在创建该存储过程时就存在,而只需在执行该存储过程时存在存储过程的执行(初次或重新编译时)存储过程初次执行或者重新编译后,查询处理器读入存储过程的处理过程称为解析数据库的某些变化会使得执行计划低效或失效,SQLServer检测这些变化并自动重新编译执行计划7存储过程的初始处理优化如果过程执行顺利通过解

6、析阶段,则查询优化器将分析该存储过程中的Transact-SQL语句,并创建一个执行计划,描述执行存储过程的最快方法编译编译指的是分析存储过程,创建执行计划并将之放入过程缓存的过程过程缓存包含了最有价值的存储过程执行计划。增加执行计划价值的因素包括:重新编译需要的时间(高的编译代价)和频繁被使用执行计划所依据的信息包括:表中的数据量;表中是否存在索引及索引的属性以及数据在索引列中的分布;WHERE子句条件所用的比较运算符和比较值;是否存在联接以及UNION、GROUPBY和ORDERBY关键字。8存

7、储过程的初始处理项存入sysobjects和syscomments表编译过的执行计划 放入过程缓存编译优化创建执行(初次或 重新编译)解析9存储过程的后续处理若符合下列条件,则SQLServer使用在内存中的计划来执行随后的查询当前的环境和计划编译时的环境相同。服务器、数据库和连接的设置决定了环境存储过程引用的对象不需要名称解析。若被不同用户拥有的对象具有相同的名字,则需要名称解析SQLServer的执行计划有两个主要部分查询计划:执行计划的主体是一个重入的只读数据结构,可由任意数量的用户使用,这称

8、为查询计划。查询计划中不存储用户环境执行环境:每个正在执行查询的用户都有一个包含其执行专用数据(如参数值)的数据结构,称为执行环境10存储过程的后续处理在缓存中,对于每个存储过程和环境的组合最多只有一个编译过的计划。对于一个存储过程的多个不同环境,可以有多个计划形成不同环境并影响编译选择的因素并行和串行编译计划隐含的对象拥有不同的SET选项一个执行计划产生后,驻留在过程缓存中。仅当需要空间时,SQLServer将老的、没用的计划移出缓存11存储过程的后续处理检索到的执

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。