陈宝刚---享受生活,追逐梦想!
理想是心中的火焰,有追求的人才是幸福的人!

*********************************************************************************
*********************              游标的使用方法          *****************************
****************                                                                      ***********************
****************     整理BY--苏贵阳   2010年7月28日      ***********************
*********************************************************************************     

一、游标的作用:
     Transact-SQL 游标主要用在存储过程、触发器和 Transact-SQL 脚本中,它们使结果集的内容对其它    Transact-SQL 语句同样可用。

二、游标的使用过程:
    
     1.声明游标变量包含游标返回的数据。
  
     2.使用declare cursor 语句把游标与一个select 语句相关联。
      如: declare CKMX_cursor cursor for
              select CKMX_WLBH,CKMX_SL,CKMX_DJ,CKMX_BZ from #CKMX  

     3.使用open语句执行select语句生成游标。
      如:  open CKMX_cursor

     4.使用fetch into 语句提取单行,并把每列中的数据转移到指定的变量中。然后,其他SQL语句可以引用这些变量来访问已提取的数据值。
      如:fetch from CKMX_cursor into @CKMX_WLBH,@CKMX_SL,@CKMX_DJ,@CKMX_BZ
      要先定义使用到的变量:
          declare @CKMX_WLBH  varchar(20)--存放从临时表中查询出来的物料代码
          declare @CKMX_SL float         --存放从临时表中查询出来的物料数量
          declare @CKMX_DJ float         --存放从临时表中查询出来的物料单价
          declare @CKMX_BZ varchar(50)   --存放从临时表中查询出来的物料备注

     5.利用while循环来遍历游标中的内容
        
         例一: 
         while @@fetch_status=0
         begin
            ……
            可以使用已经赋值了的变量: @CKMX_WLBH,@CKMX_SL,@CKMX_DJ,@CKMX_BZ

            fetch from CKMX_cursor into @CKMX_WLBH,@CKMX_SL,@CKMX_DJ,@CKMX_BZ    --如果没有此句,会导致死循环。
            ……
         end
   
         @@fetch_status 返回 fetch 语句执行的最后游标状态,而不是任何当前被打开的游标的状态。
         返回值:0:fetch语句执行成功;  -1:fetch语句执行失败,或者此行不在结果集中。
     
         例二:
              declare employee_cursor cursor for
                   select lastname, firstname from northwind.dbo.employees
              open employee_cursor
              fetch next from employee_cursor
              while @@fetch_status = 0
              begin
                  fetch next from employee_cursor
              end
              close employee_cursor
              deallocate employee_cursor

     6.结束游标:
            
             关闭当前使用的游标:   close CKMX_cursor
  
             处于关闭状态的游标,如果重新发出一个open 语句,则该游标结构仍可用于处理。

             完全释放游标资源: deallocate CKMX_cursor
      

     7.其他
             MS SQL SERVER 2000中支持 cursor 数据类型的变量。
            
             定义并关联游标变量
  
             方法一:         
             declare @myvariable cursor     -- 定义游标变量

             declare mycursor cursor for    -- 定义游标
                 select lastname from northwind.dbo.employees

             set @myvariable = mycursor     -- 关联游标
            
             方法二:
             set @myvariable = cursor scroll keyset for
                                    select lastname from northwind.dbo.employees


      
     
 

本文出自 “迷茫后的短暂停留” 博客,请务必保留此出处http://suguiyang.blog.51cto.com/1035725/416979

posted on 2011-12-30 12:30  追梦人RUBY  阅读(236)  评论(0编辑  收藏  举报