WEB开发网
开发学院数据库MSSQL Server sqlserver游标概念与实例全面解说 阅读

sqlserver游标概念与实例全面解说

 2010-03-31 00:00:00 来源:WEB开发网   
核心提示: INTO @变量名[,…] 把提取操作的列数据放到局部变量中,列表中的各个变量从左到右与游标结果集中的相应列相关联,sqlserver游标概念与实例全面解说(4),各变量的数据类型必须与相应的结果列的数据类型匹配或是结果列数据类型所支持的隐性转换,变量的数目必须与游标选择列表中的列

INTO @变量名[,…]  把提取操作的列数据放到局部变量中。列表中的各个变量从左到右与游标结果集中的相应列相关联。各变量的数据类型必须与相应的结果列的数据类型匹配或是结果列数据类型所支持的隐性转换。变量的数目必须与游标选择列表中的列的数目一致。

现在我们就取出mycursor游标的数据吧!

当游标被打开时,行指针将指向该游标集第1行之前,如果要读取游标集中的第1行数据,必须移动行指针使其指向第1行。就本例而言,可以使用下列操作读取第1行数据:

Eg: Fetch next from mycursor 或则 Fetch first from mycursor

这样我就取出了游标里的数据,但是光光这样可不够,我们还需要将取出的数据赋给变量

//声明2个变量
declare @O_ID NVARCHAR(20)
declare @A_Salary float
//将取出的值传入刚才声明的2个变量
Fetch next from mycursor into @ O_ID,@ A_Salary

1.3.4关闭游标

CLOSE mycursor   

1.3.5删除游标

DEALLOCATE mycursor         

1.3.6 实例训练

如上我介绍完了游标使用的5个步骤,那现在我们就来上上手,练习用游标取出表2 AddSalary的数据。

为了运行我们自己创建的游标,我们将游标写在存储过程里,方便我们看到游标的整个使用过程。

在sqlserver2000中新建一个存储过程:

CREATE PROCEDURE PK_Test
AS
//声明2个变量
declare @O_ID nvarchar(20)   
declare @A_Salary float
 
//声明一个游标mycursor,select语句中参数的个数必须要和从游标取出的变量名相同
declare mycursor cursor for select O_ID,A_Salary from AddSalary
 
//打开游标
open mycursor
 
//从游标里取出数据赋值到我们刚才声明的2个变量中
fetch next from mycursor into @O_ID,@A_Salary
 
//判断游标的状态
//0 fetch语句成功     
//-1 fetch语句失败或此行不在结果集中     
//-2被提取的行不存在
while (@@fetch_status=0) 
begin 
 
//显示出我们每次用游标取出的值 
   print '游标成功取出一条数据' 
   print @O_ID
   print @A_Salary
 
//用游标去取下一条记录
   fetch next from mycursor into @O_ID,@A_Salary
end 
//关闭游标
close mycursor 
//撤销游标
deallocate mycursor
GO

上一页  1 2 3 4 5  下一页

Tags:sqlserver 游标 概念

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接