T-SQL游标

使用游标的原因:

使用游标(cursor) 的一个主要的原因就是把集合操作转换成单个记录处理方式。用 SQL 语言从数据库中检索数据后,结果放在内存的一块区域中, 且结果往往是一个含有多个记录的集合(既然是集合就意味着可以含有0或1或多个记录)。游标机制允许用户在 SQL server 内逐行地访问这些记录,按照用户自己的意愿来显示和处理这些记录。

使用游标的常规步骤:

(1)  声明游标。把游标与 T-SQL 语句的结果集联系起来。 
(2)  打开游标。
(3)  使用游标操作数据。 
(4)  关闭游标。

声明游标:

DECLARE 游标名 CURSOR

FOR  SQL语句

如:

Declare MYCURSOR   Cursor

FOR Select  FROM tbMyData

打开游标

OPEN MYCURSOR  

当游标被打开时,行指针将指向该游标集第 1 行之前,如果要读取游标集中的第 1 行数据,必须移动行指针使其指向第 1 行。就本例而言,可以使用下列操作读取第 1 行数据:

FETCH NEXT from MYCURSOR   

使用游标操作数据:

在操作数据之前先介绍 全局变量 @@FETCH_STATUS:

每执行一个FETCH 操作之后,通常都要查看一下全局变量 @@FETCH_STATUS 中的状态值,以此判断 FETCH 操作是否成功。该变量有三种状态值:

 0 表示成功执行 FETCH 语句。

-1 表示 FETCH 语句失败,例如移动行指针使其超出了结果集。

-2 表示被提取的行不存在。

OPEN MYCURSOR   打开游标 

FETCH NEXT from MYCURSOR   读取第 1 行数据 

WHILE @@FETCH_STATUS = 0     用 WHILE 循环控制游标活动 

BEGIN

         FETCH NEXT from MYCURSOR   在循环体内将读取其余行数据 

END

关闭游标

CLOSE E1cursor               关闭游标 

DEALLOCATE E1cursor          删除游标
 

猜你喜欢

转载自991690137.iteye.com/blog/1944245