日期:2014-05-16  浏览次数:20584 次

数据库中的游标和触发器

1. 为何使用游标:

         使用游标(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     /*