T-SQL游标使用

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

1. 为何使用游标:

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

2. 如何使用游标:

     一般地,使用游标都遵循下列的常规步骤:

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

2.1. 声明游标

DECLARE CURSOR 语句 SQL-92 标准语法格式:

DECLARE 游标名 [ INSENSITIVE ] [ SCROLL ] CURSOR

FOR   sql-statement

Eg:

Declare MycrsrVar Cursor

FOR Select * FROM tbMyData

2.2  打开游标

OPEN MycrsrVar

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

    FETCH FIRST from E1cursor

     FETCH NEXT from E1cursor

2.3      使用游标操作数据    

下面的示例用 @@FETCH_STATUS 控制在一个 WHILE 循环中的游标活动

/* 使用游标读取数据的操作如下。 */

DECLARE E1cursor cursor     /* 声明游标,默认为 FORWARD_ONLY 游标 */

FOR SELECT * FROM c_example

OPEN E1cursor               /* 打开游标 */

FETCH NEXT from E1cursor    /* 读取第 1 行数据 */

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

BEGIN

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

END

CLOSE E1cursor              /* 关闭游标 */

DEALLOCATE E1cursor         /* 删除游标 */

2.4    关闭游标

    使用CLOSE 语句关闭游标

CLOSE { { [ GLOBAL ]游标名  } | 游标变量名  }

使用DEALLOCATE 语句删除游标,其语法格式如下:

DEALLOCATE { { [ GLOBAL ]游标名  } | @ 游标变量名 

3. FETCH操作的简明语法如下:

 FETCH

         [ NEXT | PRIOR | FIRST | LAST]

FROM

{游标名  | @ 游标变量名  } [ INTO @ 变量名  [ …] ]

参数说明:

NEXT  取下一行的数据,并把下一行作为当前行 ( 递增 ) 。由于打开游标后,行指针是指向该游标第 1 行之前,所以第一次执行 FETCH NEXT 操作将取得游标集中的第 1 行数据。 NEXT 为默认的游标提取选项。

INTO @变量名 [,…]  把提取操作的列数据放到局部变量中。列表中的各个变量从左到右与游标结果集中的相应列相关联。各变量的数据类型必须与相应的结果列的数据类型匹配或是结果列数据类型所支持的隐性转换。变量的数目必须与游标选择列表中的列的数目一致。

--------------------------------------------------------------------------------------------------------------------------------

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

· 0 表示成功执行 FETCH 语句。

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

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

由于@@FETCH_STATU 是全局变量,在一个连接上的所有游标都可能影响该变量的值。因此,在执行一条 FETCH 语句后,必须在对另一游标执行另一 FETCH 语句之前测试该变量的值才能作出正确的判断。

--示例

declare @Familyid int
declare @address nvarchar(100)

DECLARE E1cursor cursor       /* 声明游标,默认为 FORWARD_ONLY 游标  */
FOR SELECT address FROM FamilyInfo where Family_id<10
OPEN E1cursor                 /* 打开游标  */
FETCH NEXT from E1cursor into @address    /* 读取第 1 行数据 */
WHILE @@FETCH_STATUS = 0      /*  WHILE 循环控制游标活动  */
BEGIN
  SELECT * FROM mHUB_fnSplit(@address,'%') where @@rowcount<4
    FETCH NEXT from E1cursor into @address  /*读取其它记录 */
END

CLOSE E1cursor              
 DEALLOCATE E1cursor  

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值