欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

sqlserver游标的使用

程序员文章站 2024-02-10 14:04:28
...

一、游标的使用场景

我们平常对数据库中的数据进行增删改时,都是一次性处理若干行符合指定条件的数据,而如果有个业务场景,要求我们对某些数据逐行进行判断并采取不同的方式处理,这时候一般的语句就满足不了了.

游标可以方便从一个结果集中进行循环遍历数据在进行操作。它的思想就是从结果集中,一个一个取出来处理.当然,由于它是逐一处理的方式,游标的最大弊端就是低效.

二、游标的类型与格式

 游标分为两种,静态游标和动态游标,默认的都是动态游标

静态游标在打开时会将数据集存储在tempdb中,因此显示的数据与游标打开时的数据集保持一致,在游标打开以后对数据库的更新不会显示在游标中。

动态游标在打开后会反映对数据库的更改。所有UPDATE、INSERT 和 DELETE 操作都会显示在游标的结果集中,结果集中的行数据值、顺序和成员在每次提取时都会改变。

关于静态游标和动态游标的区别,可以看博主"二月十六"的《SQL SERVER 游标使用》。

--创建一个游标
declare my_cursor cursor STATIC --my_cursor为游标的名称,随便起,STATIC加上就是静态游标,去掉就是动态游标
for     
select name,id from table      --这是游标my_cursor的值,这里随便发挥看业务场景
--打开游标
open my_cursor                  --打开游标
--变量
declare   @name varchar(150)   --声明变量  ‘declare’为声明变量 ‘@name’为变量名称 后面为变量类型
declare   @id int  

--循环游标
fetch next from my_cursor into @name,@id  --获取my_cursor的下一条数据,其中字段内容分别赋值给@name 和@id
while @@FETCH_STATUS=0 --假如检索到了数据继续执行

begin

print(@name)  --这里根据业务需求定义增删改等操作

fetch next from my_cursor1 into @name,@id --获取下一条数据并赋值给变量

end--关闭释放游标
close my_cursor   --关闭游标
deallocate my_cursor   --删除游标

三、查看数据库中的游标

查看所有未关闭的游标:select * from master..syscursors where status <> -1;

查看所有游标:select * from master..syscursors;

四、举个例子

sqlserver游标的使用

有一个student表,表中有每个学生某次考试的语文、数学、英语三课成绩,现在要在表中再加一个字段rank,统计每个人的及格科目数量

解决方法有几种,这里我用最好理解的一种方法

1、定义几个变量,存放各科成绩

2、定义rank,默认初始值为0

3、逐一判断语文数学英语成绩是否及格,如果几个,rank加一

4、将rank值更新到表中

--创建一个游标
declare my_cursor1 cursor for     --my_cursor为游标的名称,随便起
select [id],[Chinese],[English],[Math] from [student]
--打开游标
open my_cursor1                  
--变量
declare   @rank int 
declare   @Chinese int 
declare   @English int 
declare   @Math int 
declare   @id int     
--循环游标
fetch next from my_cursor1 into @id,@Chinese,@English,@Math 
while @@FETCH_STATUS=0 
begin
set @rank=0  --为变量赋初始值
if @Chinese>=60 set @[email protected]+1
if @English>=60 set @[email protected]+1
if @Math>=60 set @[email protected]+1
update [student] set [rank][email protected] where [email protected]
set @[email protected]+1   --变量循环加一
fetch next from my_cursor1 into @id,@Chinese,@English,@Math  --获取下一条数据并赋值给变量

end--关闭释放游标
close my_cursor1   --关闭游标
deallocate my_cursor1   --删除游标

sqlserver游标的使用

相关标签: 游标