游标定义与使用

  1. 游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次一行或者多行前进或向后浏览数据的能力。可以把游标当作一个指针,它可以指定结果中的任何位置,然后允许用户对指定位置的数据进行处理。
    使用游标(cursor)的一个主要的原因就是把集合操作转换成单个记录处理方式。用SQL语言从数据库中检索数据后,结果放在内存的一块区域中,且结果往往是一个含有多个记录的集合。游标机制允许用户在SQL server内逐行地访问这些记录,按照用户自己的意愿来显示和处理这些记录。
    1. 如何使用游标:
      一般地,使用游标都遵循下列的常规步骤:
      (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 my_youbiao cursor
for select * from t_msg
for update

open my_youbiao
fetch next from my_youbiao
while @@fetch_status=0
begin
–update t_msg set msg=’1234567890’ where current of my_youbiao
update my_youbiao set msg=’123’ where current of my_youbiao
fetch next from my_youbiao
print ‘asdfasd11’
end
close my_youbiao
deallocate my_youbiao
print ‘asdfasd’

测试通过:

–select * from master..sysprocesses
use test
declare my_cursor cursor scroll dynamic –scroll表示可以向前或向后移动 dynamic:表示可写也可读,
for
select F3 from temp –定义my_cursor 游标

open my_cursor –打开游标
declare @name nvarchar(128) –定义一个变量
fetch next from my_cursor into @name –游标停在第一条记录前面,第一次执行,测试有没有记录存在
while(@@fetch_status=0) –取数据,直到-2即没有记录
begin
print ‘姓名: ’ + @name
–fetch next from my_cursor
fetch next from my_cursor into @name
end

–fetch first from my_cursor into @name
print @name
–update temp set F9=’zzg’ where current of my_cursor
/*// delete from 个人资料 where current of my_cursor */
close my_cursor
deallocate my_cursor

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值