declare my_cursor cursor scroll dynamic



for

select * from t_msg

open my_cursor

declare @name sysname

fetch next from my_cursor into @name

while(@@fetch_status=0)

begin

print 'UserName: ' + @name

--fetch next from my_cursor

fetch next from my_cursor into @name

end

--fetch first from my_cursor into @name

print @name





close my_cursor

deallocate my_cursor

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

FOR SELECT * FROM c_example

OPEN E1cursor

FETCH NEXT from E1cursor

WHILE @@FETCH_STATUS = 0

BEGIN

FETCH NEXT from E1cursor

END

CLOSE E1cursor

DEALLOCATE E1cursor

2.4 关闭游标

使用CLOSE语句关闭游标

CLOSE { { [ GLOBAL ] 游标名 } | 游标变量名 }

使用DEALLOCATE语句删除游标,其语法格式如下:

DEALLOCATE { { [ GLOBAL ] 游标名 } | @游标变量名

3. FETCH操作的简明语法如下:

FETCH

[ NEXT | PRIOR | FIRST | LAST]

FROM

{ 游标名 | @游标变量名 } [ INTO @变量名 [,…] ]

参数说明:

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

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

--------------------------------------------------------------------------------------------------------------------------------

每执行一个FETCH操作之后,通常都要查看一下全局变量@@FETCH_STATUS中的状态值,以此判断FETCH操作是否成功。该变量有三种状态值:

? 0 表示成功执行FETCH语句。

? -1 表示FETCH语句失败,例如移动行指针使其超出了结果集。

? -2 表示被提取的行不存在。

由于@@FETCH_STATU是全局变量,在一个连接上的所有游标都可能影响该变量的值。因此,在执行一条FETCH语句后,必须在对另一游标执行另一FETCH 语句之前测试该变量的值才能作出正确的判断。

更新数据;

declare my_youbiao cursor

for select * from t_msg

for update

open my_youbiao

fetch next from my_youbiao

while @@fetch_status=0

begin

--update t_msg set msg='1234567890' where current of my_youbiao

update my_youbiao set msg='123' where current of my_youbiao

fetch next from my_youbiao

print 'asdfasd11'

end

close my_youbiao

deallocate my_youbiao

print 'asdfasd'

测试通过:



--select * frommaster..sysprocesses

use test

declare my_cursorcursor scroll dynamic
--scroll表示可以向前或向后移动
dynamic:表示可写也可读,

for

select F3from
temp --定义my_cursor 游标



open my_cursor--打开游标

declare@name
nvarchar(128)--定义一个变量

fetchnext
from my_cursorinto
@name --游标停在第一条记录前面,第一次执行,测试有没有记录存在

while(@@fetch_status=0)--取数据,直到-2即没有记录

begin

print'姓名:
' +
@name

--fetch next from my_cursor

fetchnext
from my_cursorinto
@name

end



--fetch first from my_cursor into @name

print@name

--update temp set F9='zzg' where current of my_cursor



close my_cursor

deallocate my_cursor

最新文章

  1. window绝对路径与相对路径
  2. html select 下拉箭头隐藏
  3. prototype原型模式中的问题
  4. css各浏览器的兼容性写法
  5. [操作系统]iOS6与iOS7屏幕适配技巧
  6. HTML5 appcache
  7. uitableview 关于键盘挡住输入框解决方法
  8. Git使用规范
  9. outline
  10. web服务器,应用程序服务器,http服务器的区别
  11. Effective C++ ——实现
  12. web 高并发分析
  13. JAVA WEB快速入门之环境搭建
  14. http连接基础类,负责底层的http通信
  15. 课程回顾-Structuring Machine Learning Projects
  16. html 空格字符类型
  17. [iOS]App上架流程[利用Archive进行上传]
  18. Date和 Calendar
  19. c# Color 颜色设置
  20. Eolinker API 接口文档神器

热门文章

  1. 济南清北学堂游记 Day 5.
  2. CF 455D. Serega and Fun [分块 deque]
  3. CodeChef Cards, bags and coins [DP 泛型背包]
  4. transform复习之图片的旋转木马效果
  5. SDN第5次上机作业
  6. 小甲鱼OD学习第3讲
  7. pyhton:图像旋转
  8. JAVAEE——BOS物流项目05:OCUpload、POI、pinyin4J、重构分页代码、分区添加、combobox
  9. ubunt tftp服务器搭建
  10. php实现的短网址算法分享