1、说明游标。说明游标的时候并不执行select语句。
declare <游标名> cursor for <select语句>;
declare <游标名> cursor for <select语句>;
2、打开游标。打开游标实际上是执行相应的select语句,把查询结果读取到缓冲区中。这时候游标处于活动状态,指针指向查询结果集的第一条纪录。
open <游标名>;
open <游标名>;
3、推进游标指针并读取当前纪录。用fetch语句把游标指针向前推进一条纪录,同时将缓冲区中的当前纪录读取出来送到变量中。fetch语句通常用在一个循环结构体中,通过循环执行fetch语句逐条取出结果集中的行进行处理。现在好多数据库中,还允许任意方向任意步长易懂游标指针,而不仅仅是把游标指针向前推进一行了。
fetch <游标名> into <变量1>,<变量2>...
fetch <游标名> into <变量1>,<变量2>...
4、关闭游标。用close语句关闭游标,释放结果集占用的缓冲区及其他资源。游标关闭后,就不再和原来的查询结果集相联系。但游标可以再次打开,与新的查询结果相联系。
close <游标名>;
close <游标名>;
例子:
CREATE
PROCEDURE
[
dbo
]
.
[
pro_CURSOR
]
AS
BEGIN
-- 声明一个游标
DECLARE MyCURSOR CURSOR FOR
SELECT userid,depid FROM users
-- 打开游标
open MyCURSOR
-- 声明两个变量
declare @userid varchar ( 50 )
declare @depid varchar ( 50 )
-- 循环移动
AS
BEGIN
-- 声明一个游标
DECLARE MyCURSOR CURSOR FOR
SELECT userid,depid FROM users
-- 打开游标
open MyCURSOR
-- 声明两个变量
declare @userid varchar ( 50 )
declare @depid varchar ( 50 )
-- 循环移动
--这里会把select的变量赋给(@userid,@depid)所以select的列和变量的数量和顺序要一样
fetch next from MyCURSOR into @userid , @depid
while ( @@fetch_status = 0 )
begin
update users set description = ( select dep_des from department where depid = @depid )
where userid = @userid
fetch next from MyCURSOR into @userid , @depid
end
close MyCURSOR
deallocate MyCURSOR
END
fetch next from MyCURSOR into @userid , @depid
while ( @@fetch_status = 0 )
begin
update users set description = ( select dep_des from department where depid = @depid )
where userid = @userid
fetch next from MyCURSOR into @userid , @depid
end
close MyCURSOR
deallocate MyCURSOR
END
总结:游标就是C#中的ForEatch一个list