游标
来源:互联网 发布:手游抢激活码软件 编辑:程序博客网 时间: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