SQL游标使用及实例

declare my_cursor cursor scroll dynamic
/*scroll表示可随意移动游标指针(不然只能向前),dynamic表示能够读写游标(不然游标只读)*/
for
select * from t_msgsql

open my_cursor
declare @name sysname
fetch next from my_cursor into @name
while(@@fetch_status=0)
begin
print 'UserName: ' + @name
--fetch next from my_cursor
fetch next from my_cursor into @name
end数据库

--fetch first from my_cursor into @name
print @name
/* update 我的资料 set 姓名='zzg' where current of my_cursor */
/* delete from 我的资料 where current of my_cursor */
close my_cursor
deallocate my_cursor测试

 

使用游标(cursor)的一个主要的缘由就是把集合操做转换成单个记录处理方式。用SQL语言从数据库中检索数据后,结果放在内存的一块区域中,且结果每每是一个含有多个记录的集合。游标机制容许用户在SQL server内逐行地访问这些记录,按照用户本身的意愿来显示和处理这些记录。
2. 如何使用游标:
     通常地,使用游标都遵循下列的常规步骤:
      (1) 声明游标。把游标与T-SQL语句的结果集联系起来。
      (2) 打开游标。
      (3) 使用游标操做数据。
      (4) 关闭游标。
2.1. 声明游标
DECLARE CURSOR语句SQL-92标准语法格式:
DECLARE 游标名 [ INSENSITIVE ] [ SCROLL ] CURSOR
FOR sql-statement
Eg:
Declare MycrsrVar Cursor
FOR Select * FROM tbMyData
2.2 打开游标
OPEN MycrsrVar
当游标被打开时,行指针将指向该游标集第1行以前,若是要读取游标集中的第1行数据,必须移动行指针使其指向第1行。就本例而言,可使用下列操做读取第1行数据:
     FETCH FIRST from E1cursor
     或 FETCH NEXT from E1cursor
2.3      使用游标操做数据   
下面的示例用@@FETCH_STATUS控制在一个WHILE循环中的游标活动
/* 使用游标读取数据的操做以下。*/
DECLARE E1cursor cursor      /* 声明游标,默认为FORWARD_ONLY游标 */
FOR SELECT * FROM c_example
OPEN E1cursor                /* 打开游标 */
FETCH NEXT from E1cursor     /* 读取第1行数据*/
WHILE @@FETCH_STATUS = 0     /* 用WHILE循环控制游标活动 */
BEGIN
FETCH NEXT from E1cursor   /* 在循环体内将读取其他行数据 */
ENDfetch

CLOSE E1cursor               /* 关闭游标 */
DEALLOCATE E1cursor          /* 删除游标 */spa

2.4     关闭游标
     使用CLOSE语句关闭游标
CLOSE { { [ GLOBAL ] 游标名 } | 游标变量名 }
使用DEALLOCATE语句删除游标,其语法格式以下:
DEALLOCATE { { [ GLOBAL ] 游标名 } | @游标变量名
3. FETCH操做的简明语法以下:
FETCH
           [ NEXT | PRIOR | FIRST | LAST]
FROM
{ 游标名 | @游标变量名 } [ INTO @变量名 [,…] ]指针

参数说明:server

NEXT   取下一行的数据,并把下一行做为当前行(递增)。因为打开游标后,行指针是指向该游标第1行以前,因此第一次执行FETCH NEXT操做将取得游标集中的第1行数据。NEXT为默认的游标提取选项。内存

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

--------------------------------------------------------------------------------------------------------------------------------test

每执行一个FETCH操做以后,一般都要查看一下全局变量@@FETCH_STATUS中的状态值,以此判断FETCH操做是否成功。该变量有三种状态值:

? 0 表示成功执行FETCH语句。

? -1 表示FETCH语句失败,例如移动行指针使其超出告终果集。

? -2 表示被提取的行不存在。

因为@@FETCH_STATU是全局变量,在一个链接上的全部游标均可能影响该变量的值。所以,在执行一条FETCH语句后,必须在对另外一游标执行另外一FETCH 语句以前测试该变量的值才能做出正确的判断。

 

更新数据;
declare my_youbiao cursor
for select * from t_msg
for update

open my_youbiao
fetch next from my_youbiao
while @@fetch_status=0
begin
--update t_msg set msg='1234567890' where current of my_youbiao
update my_youbiao set msg='123' where current of my_youbiao
fetch next from my_youbiao
print 'asdfasd11'
end
close my_youbiao
deallocate my_youbiao
print 'asdfasd'

 测试经过:

 


-- select * from   master..sysprocesses
use  test
declare  my_cursor  cursor  scroll dynamic  -- scroll表示能够向前或向后移动   dynamic:表示可写也可读,
for
select  F3  from   temp   -- 定义my_cursor 游标

open  my_cursor  -- 打开游标
declare   @name   nvarchar ( 128 -- 定义一个变量
fetch   next   from  my_cursor  into   @name   -- 游标停在第一条记录前面,第一次执行,测试有没有记录存在
while ( @@fetch_status = 0 -- 取数据,直到-2即没有记录
begin
print   ' 姓名:  '   +   @name  
-- fetch next from my_cursor
fetch   next   from  my_cursor  into   @name
end

-- fetch first from my_cursor into @name
print   @name
 
-- update temp set F9='zzg' where current of my_cursor 
/* delete from 我的资料 where current of my_cursor */
close  my_cursor
deallocate  my_cursor