读取游标

读取游标是指使用fetch语句从打开的游标中逐行读取数据,以进行相关处理

语法:

fetch

{[first|last|prior|next|relative|absolute n]}

from <游标名>

[Into @<变量> [,….n]]

First :返回游标中第一行,并将其设为当前行。

Last 返回游标中的最后一行,并将其设为当前行。

Prior:返回结果集中当前行的前一行,并将其设为当前行。如果 Fetch prior是第一次读取游标中的数据,则无记录返回,并把游标位置设为第一行。

Next  返回结果集中当前行的下一行,并将其设为当前行。如果Fetch Next是第一次读取游标中数据,则返回结果集中的是第一行而不是第二行。Next 是默认的游标提取选项

Relative n:按照相对位置读取数据。如果n为正数,则返回从当前行开始向后的n行,并将其设为当前行;如果n为负数,则返回从当前行开始向前的第n行,并将其设为当前行。

Absolute n:按照绝对位置读取数据。如果n为正数,则返回从游标头开始向后的第n行,并将其设为当前行:如果n为负数,则返回从游标末尾开始第n行,并将其设为当前行。

Into @<变量> [,…..n] : 将读取的列的数据存放在多个变量中。变量的数量、排列顺序以及数据类型必须与声明游标时使用的select语句中引用的数据列数量、排列顺序以及数据类型保持一致。

使用Fetch语句一次可以提取一条记录。通过检测全局变量@@Fetch_status 的值,可以获得Fetch语句的状态信息,该状态信息可以用来判断该Fetch语句返回数据的有效性。@@Fetch_status变量有3个不同的返回值,如

返回值

描述

0

Fetch语句执行成功

-1

Fetch语句执行失败或行不在结果集中

-2

读取的行不存储

从上面的例子mycursor 读取数据,并查看Fetch 语句的状态

Fetch next from mycursor

select ‘执行状态’==@@Fetch_status

原文地址:https://www.cnblogs.com/xiaowie/p/8676174.html