游标

来源:互联网 发布:手游抢激活码软件 编辑:程序博客网 时间:2024/06/08 16:06
对于sql语句查询的结果集,有时需要每次只处理一行,此时用游标。

语句:
declare 游标名 cursor //用for后面的内容声明一个游标
for 查询语句(如select * from 表名)
open 游标名; //打开游标
fetch next from 游标名; //读取游标
close 游标名; //关闭游标
deallocate 游标名; //删除游标

示例:
  1 --声明一个游标
  2 DECLARE MyCursor CURSOR
  3 FOR SELECT TOP 5 FBookName,FBookCoding FROM TBookInfo//定义一个叫MyCursor的游标,存放for select 后的数据
    
  5 --打开一个游标
  6 OPEN MyCursor//即打开这个数据集
    
  8 --循环一个游标
  9 DECLARE @BookName nvarchar(2000),@BookCoding nvarchar(2000)
 10 FETCH NEXT FROM  MyCursor INTO @BookName,@BookCoding//移动游标指向到第一条数据,提取第一条数据存放在变量中    
 11 WHILE @@FETCH_STATUS =0//如果上一次操作成功则继续循环
 12 BEGIN
 13 print 'name'+@BookName
 14 FETCH NEXT FROM  MyCursor INTO @BookName,@BookCoding//继续提下一行
 15 END
 16 
 17 --关闭游标
 18 CLOSE MyCursor
 19 --释放资源
 20 DEALLOCATE MyCursor

原创粉丝点击