游标的定义
游标是SQL 的一种数据访问机制。可以将游标简单的看成是查询的结果集的一个指针,可以根据需要在结果集上面来回滚动,浏览需要的数据。
游标的分类
- 静态游标
静态游标的结果集,在游标打开的时候建立在TempDB中,不论你在操作游标的时候,如何操作数据库,游标中的数据集都不会变。如果想与操作之后的数据一致,则重新关闭打开游标即可。
- 动态游标
这个则与静态游标相对,滚动游标时,动态游标反应结果集中的所有更改。结果集中的行数据值、顺序和成员在每次提取时都会变化。所有用户做的增删改语句通过游标均可见。如果使用API函数或T-SQL Where Current of子句通过游标进行更新,他们将立即可见。在游标外部所做的更新直到提交时才可见。
- 只进游标
只进游标不支持滚动,只支持从头到尾顺序提取数据,数据库执行增删改,在提取时是可见的,但由于该游标只能进不能向后滚动,所以在行提取后对行做增删改是不可见的。
- 键集驱动游标
打开键集驱动游标时,该有表中的各个成员身份和顺序是固定的。打开游标时,结果集这些行数据被一组唯一标识符标识,被标识的列做删改时,用户滚动游标是可见的,如果没被标识的列增该,则不可见,比如insert一条数据,是不可见的,若可见,须关闭重新打开游标。 静态游标在滚动时检测不到表数据变化,但消耗的资源相对很少。动态游标在滚动时能检测到所有表数据变化,但消耗的资源却较多。键集驱动游标则处于他们中间,所以根据需求建立适合自己的游标,避免资源浪费。
优点
游标允许应用程序对查询语句select返回的行结果集中每一行进行相同或不同的操作,而不是一次对整个结果集进行同一种操作;它还提供对基于游标位置而对表中数据进行删除或更新的能力;而且,正是游标把作为面向集合的数据库管理系统和面向行的程序设计两者联系起来,使两个数据处理方式能够进行沟通
缺点
游标速度较慢。
使用游标的五个阶段
- 声明游标
- 打开游标
- 读取游标数据
- 关闭游标
- 释放游标
使用方法
下面展示一些 `
--根据价格设置每本书的等级
--价格<50 便宜
-- >=50-100 中等
-- >=100 贵
--定义一个游标
declare cur_set_lever CURSOR
for select id,Price from books
--打开游标
open cur_set_lever
--获取数据 id,price
declare @id int
declare @price decimal(18,2)
fetch next from cur_set_lever
into @id,@price
print @id
--循环获取id
while (@@FETCH_STATUS=0)
begin
--修改等级
if (@price<50)
update books set Levels='便宜' where id=@id
else if(@price<100)
update books set Levels='中等' where id=@id
else
update books set Levels='贵' where id=@id
fetch next from cur_set_lever
into @id,@price
end
--关闭游标
close cur_set_lever
--释放游标
deallocate cur_set_lever