游标 学习笔记

   1.使用游标的原因:

     使用游标(cursor)的一个主要的原因就是把集合操作转换成单个记录处理方式。用SQL语言从数据库中检索数据后,结果放在内存的一块区域中,且结果往往是一个含有多个记录的集合。游标机制允许用户在SQL server内逐行地访问这些记录,按照用户自己的意愿来显示和处理这些记录。

   2.使用游标的常规步骤:

      (1)  声明游标。把游标与T-SQL语句的结果集联系起来。

            DECLARE 游标名 [ INSENSITIVE ] [ SCROLL ] CURSOR

            FOR  sql-statement 
        (2)  打开游标。

            OPEN MycrsrVar

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

               FETCH FIRST from 游标名     或 FETCH NEXT from 游标名 

       (3)  使用游标操作数据。
            WHILE @@FETCH_STATUS = 0

             @@fetch_status是MSSQL的一个全局变量,其返回值有三种【返回类型integer】
             0       FETCH 语句成功
             -1      FETCH 语句失败或此行不在结果集中
             -2      被提取的行不存在
       (4)  关闭游标。

            CLOSE { { [ GLOBAL ] 游标名 } | 游标变量名 }
      (5)删除游标
            DEALLOCATE { { [ GLOBAL ] 游标名 } | @游标变量名  
      游标实例:
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   /* 在循环体内将读取其余行数据 */ 
END 

CLOSE E1cursor               /* 关闭游标 */ 

DEALLOCATE E1cursor          /* 删除游标 */ 

参数说明:

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

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

猜你喜欢

转载自adla-bin.iteye.com/blog/1860701
今日推荐