操作游标的标准步骤.doc

上传人:dwx****52 文档编号:2970865 上传时间:2019-05-13 格式:DOC 页数:3 大小:21.50KB
下载 相关 举报
操作游标的标准步骤.doc_第1页
第1页 / 共3页
操作游标的标准步骤.doc_第2页
第2页 / 共3页
操作游标的标准步骤.doc_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

1、游标操作基本步骤 2010-08-30 21:39 1. 为何使用游标: 使用游标 (cursor)的一个主要的原因就是 把集合操作转换成单个记录处理方式 。用 SQL语言从数据库中检索数据后,结果放在内存的一块区域中,且结果往往是一个含有多个记录的集合。游标机制允许用户在 SQL server内逐行地访问这些记录,按照用户自己的意愿来显示和处理这些记录。 2. 如何使用游标: 一般地,使用游标都遵循下列的常规步骤: (1) 声明游标。把游标与 T-SQL语句的结果集联系起来。 (2) 打开游标。 (3) 使用游标操作数据。 (4) 关闭游标。 2.1. 声明游标 DECLARE CURSOR

2、语句 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 使用游标操作数

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 /* 在循环体内将读取其余行数

4、据 */ END CLOSE E1cursor /* 关闭游标 */ DEALLOCATE E1cursor /* 删除游标 */ 2.4 关闭游标 使用 CLOSE语句关闭游标 CLOSE GLOBAL 游标名 | 游标变量名 使用 DEALLOCATE语句删除游标,其语法格式如下: DEALLOCATE GLOBAL 游标名 | 游标变量名 3. FETCH操作的简明语法如下: FETCH NEXT | PRIOR | FIRST | LAST FROM 游标名 | 游标变量名 INTO 变量名 , 参数说明: NEXT 取下一行的数据,并把下一行作为当前行 (递增 )。由于打开游标后,行

5、指针是指向该游标第 1行之前,所以第一次执行 FETCH NEXT操作将取得游标集中的第 1行数据。 NEXT为默认的游标提取选项。 INTO 变量名 , 把提取操作的列数据放到局部变量中。列表中的各个变量从左到右与游标结果集中的相应列相关联。各变量的数据类型必须与相应的结果列的数据类型匹配或是结果列数据类型所支持的隐性转换。变量的数目必须与 游标选择列表中的列的数目一致。 - 每执行一个 FETCH 操作之后,通常都要查看一下全局变量 FETCH_STATUS 中的状态值,以此判断 FETCH操作是否成功。该变量有三种状态值: 0 表示成功执行 FETCH语句。 -1 表示 FETCH语句失

6、败,例 如移动行指针使其超出了结果集。 -2 表示被提取的行不存在。 由于 FETCH_STATU是全局变量,在一个连接上的所有游标都可能影响该变量的值。因此,在执行一条 FETCH语句后,必须在对另一游标执行另一 FETCH 语句之前测试该变量的值才能作出正确的判断。 下例显示如何嵌套游标以生成复杂的报表。为每个作者声明内部游标。 SET NOCOUNT ON DECLARE au_id varchar(11), au_fname varchar(20), au_lname varchar(40), message varchar(80), title varchar(80) PRINT “

7、- Utah Authors report -“ DECLARE authors_cursor CURSOR FOR SELECT au_id, au_fname, au_lname FROM authors WHERE state = “UT“ ORDER BY au_id OPEN authors_cursor FETCH NEXT FROM authors_cursor INTO au_id, au_fname, au_lname WHILE FETCH_STATUS = 0 BEGIN PRINT “ “ SELECT message = “- Books by Author: “ +

8、 au_fname + “ “ + au_lname PRINT message - Declare an inner cursor based - on au_id from the outer cursor. DECLARE titles_cursor CURSOR FOR SELECT t.title FROM titleauthor ta, titles t WHERE ta.title_id = t.title_id AND ta.au_id = au_id - Variable value from the outer cursor OPEN titles_cursor FETCH

9、 NEXT FROM titles_cursor INTO title IF FETCH_STATUS “ WHILE FETCH_STATUS = 0 BEGIN SELECT message = “ “ + title PRINT message FETCH NEXT FROM titles_cursor INTO title END CLOSE titles_cursor DEALLOCATE titles_cursor - Get the next author. FETCH NEXT FROM authors_cursor INTO au_id, au_fname, au_lname END CLOSE authors_cursor DEALLOCATE authors_cursor GO

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 实用文档资料库 > 策划方案

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。