SqlServer存储过程中使用Cursor(游标)操作记录
2012-07-25 09:38
531 查看
1.为何使用游标:使用游标(cursor)的一个主要的原因就是把集合操作转换成单个记录处理方式。用SQL语言从数据库中检索数据后,结果放在内存的一块区域中,且结果往往是一个含有多个记录的集合。游标机制允许用户在SQLserver内逐行地访问这些记录,按照用户自己的意愿来显示和处理这些记录。
2.如何使用游标:一般地,使用游标都遵循下列的常规步骤:
(1)声明游标。把游标与T-SQL语句的结果集联系起来。
(2)打开游标。
(3)使用游标操作数据。
(4)关闭游标。
2.1.声明游标
DECLARECURSOR语句SQL-92标准语法格式:
DECLARE游标名[INSENSITIVE][SCROLL]CURSOR
FORsql-statement
Eg:
DeclareMycrsrVarCursor
FORSelect*FROMtbMyData
2.2打开游标
OPENMycrsrVar
当游标被打开时,行指针将指向该游标集第1行之前,如果要读取游标集中的第1行数据,必须移动行指针使其指向第1行。就本例而言,可以使用下列操作读取第1行数据:
FETCHFIRSTfromE1cursor
或FETCHNEXTfromE1cursor
2.3使用游标操作数据
下面的示例用@@FETCH_STATUS控制在一个WHILE循环中的游标活动
/*使用游标读取数据的操作如下。*/
DECLAREE1cursorcursor/*声明游标,默认为FORWARD_ONLY游标*/
FORSELECT*FROMc_example
OPENE1cursor/*打开游标*/
FETCHNEXTfromE1cursor/*读取第1行数据*/
WHILE@@FETCH_STATUS=0/*用WHILE循环控制游标活动*/
BEGIN
FETCHNEXTfromE1cursor/*在循环体内将读取其余行数据*/
END
CLOSEE1cursor/*关闭游标*/
DEALLOCATEE1cursor/*删除游标*/
2.4关闭游标
使用CLOSE语句关闭游标
CLOSE{{[GLOBAL]游标名}|游标变量名}
使用DEALLOCATE语句删除游标,其语法格式如下:
DEALLOCATE{{[GLOBAL]游标名}|@游标变量名
3.FETCH操作的简明语法如下:FETCH
[NEXT|PRIOR|FIRST|LAST]
FROM
{游标名|@游标变量名}[INTO@变量名[,…]]
参数说明:
NEXT取下一行的数据,并把下一行作为当前行(递增)。由于打开游标后,行指针是指向该游标第1行之前,所以第一次执行FETCHNEXT操作将取得游标集中的第1行数据。NEXT为默认的游标提取选项。
INTO@变量名[,…]把提取操作的列数据放到局部变量中。列表中的各个变量从左到右与游标结果集中的相应列相关联。各变量的数据类型必须与相应的结果列的数据类型匹配或是结果列数据类型所支持的隐性转换。变量的数目必须与游标选择列表中的列的数目一致。
--------------------------------------------------------------------------------------------------------------------------------
每执行一个FETCH操作之后,通常都要查看一下全局变量@@FETCH_STATUS中的状态值,以此判断FETCH操作是否成功。该变量有三种状态值:
·0表示成功执行FETCH语句。
·-1表示FETCH语句失败,例如移动行指针使其超出了结果集。
·-2表示被提取的行不存在。
由于@@FETCH_STATU是全局变量,在一个连接上的所有游标都可能影响该变量的值。因此,在执行一条FETCH语句后,必须在对另一游标执行另一FETCH语句之前测试该变量的值才能作出正确的判断。
下例显示如何嵌套游标以生成复杂的报表。为每个作者声明内部游标。
2.如何使用游标:一般地,使用游标都遵循下列的常规步骤:
(1)声明游标。把游标与T-SQL语句的结果集联系起来。
(2)打开游标。
(3)使用游标操作数据。
(4)关闭游标。
2.1.声明游标
DECLARECURSOR语句SQL-92标准语法格式:
DECLARE游标名[INSENSITIVE][SCROLL]CURSOR
FORsql-statement
Eg:
DeclareMycrsrVarCursor
FORSelect*FROMtbMyData
2.2打开游标
OPENMycrsrVar
当游标被打开时,行指针将指向该游标集第1行之前,如果要读取游标集中的第1行数据,必须移动行指针使其指向第1行。就本例而言,可以使用下列操作读取第1行数据:
FETCHFIRSTfromE1cursor
或FETCHNEXTfromE1cursor
2.3使用游标操作数据
下面的示例用@@FETCH_STATUS控制在一个WHILE循环中的游标活动
/*使用游标读取数据的操作如下。*/
DECLAREE1cursorcursor/*声明游标,默认为FORWARD_ONLY游标*/
FORSELECT*FROMc_example
OPENE1cursor/*打开游标*/
FETCHNEXTfromE1cursor/*读取第1行数据*/
WHILE@@FETCH_STATUS=0/*用WHILE循环控制游标活动*/
BEGIN
FETCHNEXTfromE1cursor/*在循环体内将读取其余行数据*/
END
CLOSEE1cursor/*关闭游标*/
DEALLOCATEE1cursor/*删除游标*/
2.4关闭游标
使用CLOSE语句关闭游标
CLOSE{{[GLOBAL]游标名}|游标变量名}
使用DEALLOCATE语句删除游标,其语法格式如下:
DEALLOCATE{{[GLOBAL]游标名}|@游标变量名
3.FETCH操作的简明语法如下:FETCH
[NEXT|PRIOR|FIRST|LAST]
FROM
{游标名|@游标变量名}[INTO@变量名[,…]]
参数说明:
NEXT取下一行的数据,并把下一行作为当前行(递增)。由于打开游标后,行指针是指向该游标第1行之前,所以第一次执行FETCHNEXT操作将取得游标集中的第1行数据。NEXT为默认的游标提取选项。
INTO@变量名[,…]把提取操作的列数据放到局部变量中。列表中的各个变量从左到右与游标结果集中的相应列相关联。各变量的数据类型必须与相应的结果列的数据类型匹配或是结果列数据类型所支持的隐性转换。变量的数目必须与游标选择列表中的列的数目一致。
--------------------------------------------------------------------------------------------------------------------------------
每执行一个FETCH操作之后,通常都要查看一下全局变量@@FETCH_STATUS中的状态值,以此判断FETCH操作是否成功。该变量有三种状态值:
·0表示成功执行FETCH语句。
·-1表示FETCH语句失败,例如移动行指针使其超出了结果集。
·-2表示被提取的行不存在。
由于@@FETCH_STATU是全局变量,在一个连接上的所有游标都可能影响该变量的值。因此,在执行一条FETCH语句后,必须在对另一游标执行另一FETCH语句之前测试该变量的值才能作出正确的判断。
下例显示如何嵌套游标以生成复杂的报表。为每个作者声明内部游标。
SETNOCOUNTON
DECLARE@au_idvarchar(11),@au_fnamevarchar(20),@au_lnamevarchar(40),
@messagevarchar(80),@titlevarchar(80)
PRINT"--------UtahAuthorsreport--------"
DECLAREauthors_cursorCURSORFOR
SELECTau_id,au_fname,au_lname
FROMauthors
WHEREstate="UT"
ORDERBYau_id
OPENauthors_cursor
FETCHNEXTFROMauthors_cursor
INTO@au_id,@au_fname,@au_lname
WHILE@@FETCH_STATUS=0
BEGIN
PRINT""
SELECT@message="-----BooksbyAuthor:"+
@au_fname+""+@au_lname
PRINT@message
--Declareaninnercursorbased
--onau_idfromtheoutercursor.
DECLAREtitles_cursorCURSORFOR
SELECTt.title
FROMtitleauthorta,titlest
WHEREta.title_id=t.title_idAND
ta.au_id=@au_id--Variablevaluefromtheoutercursor
OPENtitles_cursor
FETCHNEXTFROMtitles_cursorINTO@title
IF@@FETCH_STATUS<>0
PRINT"<<NoBooks>>"
WHILE@@FETCH_STATUS=0
BEGIN
SELECT@message=""+@title
PRINT@message
FETCHNEXTFROMtitles_cursorINTO@title
END
CLOSEtitles_cursor
DEALLOCATEtitles_cursor
--Getthenextauthor.
FETCHNEXTFROMauthors_cursor
INTO@au_id,@au_fname,@au_lname
END
CLOSEauthors_cursor
DEALLOCATEauthors_cursor
GO
相关文章推荐
- 在SqlServer存储过程中使用Cursor(游标)操作记录
- 在SqlServer存储过程中使用Cursor(游标)操作记录
- 在SqlServer存储过程中使用Cursor(游标)操作记录
- SAP HANA存储过程中的游标使用(Cursor)
- mysql存储过程使用CURSOR操作多列数据实用案例
- Oracle 存储过程中使用cursor 游标遍历数据
- Oracle 存储过程中使用cursor 游标遍历数据
- sqlserver 使用游标存储过程分页
- SQL Server学习:存储过程中Cursor(游标)的使用
- 数据库操作_连接SQL Server数据库示例;连接ACCESS数据库;连接到 Oracle 数据库示例;SqlCommand 执行SQL命令示例;SqlDataReader 读取数据示例;使用DataAdapter填充数据到DataSet;使用DataTable存储数据库表;将数据库数据填充到 XML 文件;10 使用带输入参数的存储过程;11 使用带输入、输出参数的存储过程示;12 获得数据库中表的数目和名称;13 保存图片到SQL Server数据库示例;14 获得插入记录标识号;Exce
- cursor游标(Mysql 存储过程之结果集的循环操作)
- 关于在存储过程中使用游标操作数据库
- 如何删除一个表中重复的记录? 、、游标,存储过程的使用
- oracle存储过程中使用Ref Cursor强类型游标返回结果集
- Sql存储过程游标循环的用法及sql如何使用cursor写一个简单的循环
- MYSQL存储过程循环CURSOR(游标)使用
- 关于在存储过程中使用游标操作数据库
- 在ASP.NET 2.0中操作数据之六十六:在TableAdapters中使用现有的存储过程
- 使用系统存储过程来监控SQLServer进程和会话详解
- 使用游标编写的存储过程进行分页