1、静态游标(不检测数据行的变化)
2、动态游标(反映所有数据行的改变)
3、仅向前游标(不支持滚动)
4、键集游标(能反映修改,但不能准确反映插入、删除)
游标使用顺序:
1、定义游标
2、打开游标
3、使用游标
4、关闭游标
5、释放游标
Transact-SQL:
declare 游标名 cursor [LOCAL | GLOBAL][FORWARD_ONLY | SCROLL][STATIC | KEYSET | DYNAMIC ] [READ_ONLY | SCROLL_LOCKS]
for selet语句 [for update[of 列名[,列名]]
注:LOCAL 局部游标 GLOBAL 全局游标
FORWARD_ONLY 仅向前 SCROLL 滚动
STATIC 静态 KEYSET 键集 DYNAMIC 动态
READ_ONLY 只读 SCROLL_LOCKS 锁定游标当前行
获取游标的数据
FETCH [[NEXT | PRIOR | FIRST | LAST |
ABSOLUTE{ n | @nvar | RELATIVE { n | @nvar}]
From ] 游标名 [into 变量]
注:
NEXT 下一行 PRIOR 上一行 FIRST 第一行
LAST 最后一行 ABSOLUTE n 第n行
RELATIVE n 当前位置开始的第n行
into 变量 把当前行的各字段值赋值给变量
游标状态变量:
@@fetch_status 游标状态
0 成功 -1 失败 -2 丢失
@@cursor_rows 游标中结果集中的行数
n 行数 -1 游标是动态的 0 空集游标
操作游标的当前行:
current of 游标名
以下例子,在SQL SERVER 2000 测试成功
go
declare @auid char( 12), @aulname varchar( 20), @aufname varchar( 20), @st char( 2), @auinfo varchar( 50)
declare auth_cur cursor for --定义游标cursor1
select au_id, au_lname, au_fname, state from authors -- 使用游标的对象(跟据需要填入select文)
open auth_cur -- 打开游标
fetch next from auth_cur into @auid, @aulname, @aufname, @st --将游标向下移1行,获取的数据放入之前定义的变量@id,@name中
while ( @@fetch_status = 0) -- 判断是否成功获取数据
begin
print ' 作者编号: ' + @auid
print ' 作者姓名: ' + @aulname + ' , ' + @aufname --进行相应处理(跟据需要填入SQL文)
print ' 所在州: ' + @st
print ' -------------------------- '
fetch next from auth_cur into @auid, @aulname, @aufname, @st --将游标向下移1行
end
close auth_cur -- 关闭游标
deallocate auth_cur
Transact-SQL 游标主要用于存储过程、触发器和Transact-SQL 脚本中,它们使结果集的内容可用于其他Transact-SQL 语句。
游标for循环示显示游标的一种快捷使用方式,它使用for循环依次读取结果集中的行数据,当form循环开始时,游标自动打开(不需要open),每循环一次系统自动读取游标当前行的数据(不需要fetch),当退出for循环时,游标被自动关闭(不需要使用close)。