游标简介与使用方法

游标简介与使用方法

ID:39659439

大小:21.67 KB

页数:5页

时间:2019-07-08

游标简介与使用方法_第1页
游标简介与使用方法_第2页
游标简介与使用方法_第3页
游标简介与使用方法_第4页
游标简介与使用方法_第5页
资源描述:

《游标简介与使用方法》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、SQLServer游标简介与使用说明      游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次以行或者多行前进或向后浏览数据的能力。我们可以把游标当作一个指针,它可以指定结果中的任何位置,然后允许用户对指定位置的数据进行处理。      1.游标的组成      游标包含两个部分:一个是游标结果集、一个是游标位置。      游标结果集:定义该游标得SELECT语句返回的行的集合。游标位置:指向这个结果集某一行的当前指针。       2.游标的分类      游标共有3类:API服务器游标、Transaction-SQL游标和API客户端游

2、标。      其中前两种游标都是运行在服务器上的,所以又叫做服务器游标。      API服务器游标      API服务器游标主要应用在服务上,当客户端的应用程序调用API游标函数时,服务器会对API函数进行处理。使用API函数和方法可以实现如下功能:      (1)打开一个连接。      (2)设置定义游标特征的特性或属性,API自动将游标影射到每个结果集。      (3)执行一个或多个Transaction-SQL语句。      (4)使用API函数或方法提取结果集中的行。      API服务器游标包含以下四种:静态游标、动态游标、只进游标、键集驱动游标(Primarykey

3、)      静态游标的完整结果集将打开游标时建立的结果集存储在临时表中,(静态游标始终是只读的)。静态游标具有以下特点:总是按照打开游标时的原样显示结果集;不反映数据库中作的任何修改,也不反映对结果集行的列值所作的更改;不显示打开游标后在数据库中新插入的行;组成结果集的行被其他用户更新,新的数据值不会显示在静态游标中;但是静态游标会显示打开游标以后从数据库中删除的行。      动态游标与静态游标相反,当滚动游标时动态游标反映结果集中的所有更改。结果集中的行数据值、顺序和成员每次提取时都会改变。      只进游标不支持滚动,它只支持游标从头到尾顺序提取数据行。注意:只进游标也反映对结果集所

4、做的所有更改。      键集驱动游标同时具有静态游标和动态游标的特点。当打开游标时,该游标中的成员以及行的顺序是固定的,键集在游标打开时也会存储到临时工作表中,对非键集列的数据值的更改在用户游标滚动的时候可以看见,在游标打开以后对数据库中插入的行是不可见的,除非关闭重新打开游标。       Transaction-SQL游标      该游标是基于DeclareCursor语法,主要用于Transaction-SQL脚本、存储过程以及触发器中。Transaction-SQL游标在服务器处理由客户端发送到服务器的Transaction-SQL语句。      在存储过程或触发器中使用Tran

5、saction-SQL游标的过程为:      (1)声明Transaction-SQL变量包含游标返回的数据。为每个结果集列声明一个变量。声明足够大的变量来保存列返回的值,并声明变量的类型为可从数据类型隐式转换得到的数据类型。      (2)使用DeclareCursor语句将Transaction-SQL游标与Select语句相关联。还可以利用DeclareCursor定义游标的只读、只进等特性。       (3)使用Open语句执行Select语句填充游标。      (4)使用FetchInto语句提取单个行,并将每列中得数据移至指定的变量中。注意:其他Transaction-SQ

6、L语句可以引用那些变量来访问提取的数据值。Transaction-SQL游标不支持提取行块。      (5)使用Close语句结束游标的使用。注意:关闭游标以后,该游标还是存在,可以使用Open命令打开继续使用,只有调用Deallocate语句才会完全释放。      客户端游标      该游标将使用默认结果集把整个结果集高速缓存在客户端上,所有的游标操作都在客户端的高速缓存中进行。注意:客户端游标只支持只进和静态游标。不支持其他游标。       3.游标的生命周期      游标的生命周期包含有五个阶段:声明游标、打开游标、读取游标数据、关闭游标、释放游标。      声明游标是为游标

7、指定获取数据时所使用的Select语句,声明游标并不会检索任何数据,它只是为游标指明了相应的Select 语句。      Declare游标名称Cursor参数      声明游标的参数            (1)Local与Global:Local表示游标的作用于仅仅限于其所在的存储过程、触发器以及批处理中、执行完毕以后游标自动释放。Global表示的是该游标作用域是整个会话层。由连接执行的

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

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

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