0

0

sql server 中游标的使用方法(创建、打开、读取、关闭、删除)

高洛峰

高洛峰

发布时间:2016-12-14 11:54:55

|

8989人浏览过

|

来源于php中文网

原创

 一、遇到的问题

  实际上,也不算什么太大的问题O(∩_∩)O:我们有时候可能希望在批处理或者存储过程中直接对select结果集进行加工 ,这个时候,我们需要一种能够让我们逐条处理每一行记录 的数据库对象。

  二、游标的概念

  解决上面的问题,我们可以使用一种叫做“游标”的数据库对象。

  游标(Cursor) 可以看做一种数据类型,它可以用来遍历结果集,相当于指针,或者是数组中的下标。它处理结果集的方法有以下几种:

  定位到结果集的某一行

  从当前结果集的位置搜索一行或一部分行

  对结果集中的当前行进行数据修改

  三、游标的使用方法(创建、打开、读取、关闭、删除)

  【创建游标】

  和定义各种数据类型的方法有点像,但是注意,不要加“@”(实际上也有“游标类型的变量”,和“游标”的用法几乎完全相同,而且定义时使用@符 号)。下面是定义游标的语句:

  declare 游标名 cursor [local|global] [forward_only|scroll]

  for

  select查询语句

  游标分为局部游标和全局游标两种,local表示局部游标,global表示全局游标(默认值,可以省略)。当指定 forward_only(默认值,可以省略)时,游标是只进的,也就是说只能从头到尾地提取记录,如果需要在行之间来回跳跃,需要指定为scroll。

  【使用游标】

  只创建游标但是不使用它,就没有任何意义了。下面我们先举个最简单的例子来演示创建好游标之后的几步使用过程:

  --【创建游标】

  declare C1 cursor for select xingming from yiren

  declare @xingming varchar(20)

  --【打开游标】

  open C1

  --【读取游标】

  fetch next from C1 into @xingming --while的特点就是要先写一次

  while(@@FETCH_STATUS=0)

  begin

  print '姓名:'+@xingming

  fetch next from C1 into @xingming

  end

  --【关闭游标】

  close C1

  --【删除游标】

  deallocate C1

  游标的使用方法是不是和Java中的 whle(rs.next()){}很像呢?实际上rs.next()执行时就直接在结果集中向后移动一条了,如果没有到达结果集的末端,仍然会执行循环 体。在这里使用游标也是一样,@@FETCH_STATUS的值为0时,游标尚未走到结尾。当它不为0了,游标就走到了结尾,将退出循环。

  fetch next from 游标名 into 变量名列表 是一种固定形式的读取游标内容的方法。当查询语句选择了多个字段的时候,读取时也需要借助这句话向多个变量赋值。于是写成变量名列表。

  【全局游标和scroll游标】

  前面提到全局游标和scroll游标,下面举个例子:

  if(CURSOR_STATUS('global','CURSOR_2')!=-3) deallocate CURSOR_2

  declare CURSOR_2 cursor scroll --全局的scroll游标

  for select xingming,nicheng,xingbie from yiren

  --第一个T-SQL批开始

  open CURSOR_2

  declare @seq int,

  @xingming varchar(20),@nicheng varchar(50),@xingbie nchar

  set @seq=4

  fetch absolute @seq from CURSOR_2 into @xingming,@nicheng,@xingbie

  if(@@FETCH_STATUS=0)

  begin

  print '第'+cast(@seq as varchar)+'个艺人是:'+@xingming

  print case @xingbie when '男' then '他' when '女' then '她' end

  +'的昵称是:'+@nicheng

  end

  close CURSOR_2

  go

  --第二个T-SQL批开始

  open CURSOR_2

  declare @seq int,

  @xingming varchar(20),@nicheng varchar(50),@xingbie nchar

  set @seq=5 --分成了两个批,需要再次定义@seq

  fetch absolute @seq from CURSOR_2 into @xingming,@nicheng,@xingbie

  if(@@FETCH_STATUS=0)

  begin

  print '第'+cast(@seq as varchar)+'个艺人是:'+@xingming

  print case @xingbie when '男' then '他' when '女' then '她' end

  +'的昵称是:'+@nicheng

  end

  close CURSOR_2

  go

  --在第三个批中删除游标

  deallocate CURSOR_2

  当开启了scroll选项后,fetch可以用于读next(后移)、prior(前移)、first(第一行)、last(最后一行)、 absolute(以数值定位到绝对行)、relative(以数值定位到相对行) 。

  全局游标一旦被定义就会一直存在,所以每个批处理都能看到它。直到使用deallocate来删除它,它才会消失。 CURSOR_STATUS('global','CURSOR_2')可以检查它的状态。

  【游标的嵌套】

  由于大大影响系统性能,简单了解一下即可。

  if(CURSOR_STATUS('global','CURSOR_3')!=-3) deallocate CURSOR_3

  declare CURSOR_3 cursor for

Android开发教程与笔记pdf版
Android开发教程与笔记pdf版

Android文件存取与数据库编程知识,文件操作主要是读文件、写文件、读取静态文件等,同时还介绍了创建添加文件内容并保存,打开文件并显示内容;数据库编程方面主要介绍了SQLite数据库的使用、包括创建、删除、打开数据库、非查询SQL操作指令、查询SQL指令-游标Cursors等知识。

下载

  select yanchuid from yanchu

  open CURSOR_3

  declare @ycid int

  fetch next from CURSOR_3

  into @ycid

  while(@@FETCH_STATUS=0)

  begin

  print '参加第'+cast(@ycid as varchar)+'次演出的艺人是:'

  declare CURSOR_4 cursor for

  select xingming from yiren where yirenid in

  (select yirenid from yanchuyiren where yanchuid=@ycid)

  --这句使用了子查询,实际上可以再嵌套一个游标

  declare @xingming varchar(50)

  open CURSOR_4

  fetch next from CURSOR_4 into @xingming

  while(@@FETCH_STATUS=0)

  begin

  print @xingming

  fetch next from CURSOR_4 into @xingming

  end

  close CURSOR_4

  deallocate CURSOR_4

  fetch next from CURSOR_3

  into @ycid

  print ''

  end

  close CURSOR_3

  deallocate CURSOR_3

  【游标变量】

  游标变量是真正的把游标当做数据类型来使用的一种方法,游标变量和游标对象的区别就在于是否有@。创建游标变量的时候,首先declare @游标变量名 cursor,然后set @游标变量名=cursorfor select语句。

  declare @c1 CURSOR

  set @c1=cursor for select xingming from yiren

  open @c1

  declare @xingming varchar(50)

  fetch next from @c1 into @xingming

  print @xingming

  close @c1

  deallocate @c1

  四、游标的注意事项

  【游标的缺点】

  使用游标会把结果集一条条取出来处理,增加了服务器的负担,再者使用游标的效率远远没有使用默认结果集的效率高。所以,能不用游标就尽量不要 用。

  【游标的补充说明】

  当我们刚刚打开一个游标的时候,它并不指向第一条记录,而是指向第一条记录的前边。我们可以拿书做比喻,游标不仅仅可以指向记录集中的记录(书 内容的每一页),也可以指向记录集外部没有记录的地方(书的封面和封底)。

  @@fetch_status有3种取值:0表示fetch 正常执行、-1表示fetch超出了结果集、-2表示fetch所指向的行已经不存在了。

  五、修改分页查询存储过程,使用游标

  将第一个分支修改成如下代码:

  if @currentpage >1

  begin

  if @currentpage>@totalpages

  begin

  set @currentpage = @totalpages

  end

  declare @start int,@count int

  set @count = 0

  set @start = @currentpage*@pagesize+1

  set @sql='declare cursor_1 cursor scroll for select * from '

  +@tablename+' order by '+@idname

  exec(@sql)

  open cursor_1

  fetch relative @start,@pagesize from cursor_1

  while @@fetch_status=0

  begin

  set @count = @count+1

  fetch next from cursor_1

  if @count=@pagesize-1

  break

  end

  close cursor_1

  deallocate cursor_1

  end

  并去掉原来go前面的

  exec(@sql)

  即可。如果不去掉这句,会在存储过程的最后额外再执行一次这句话,从而错误地再次生成@cursor_1游标。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

150

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

88

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

90

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

61

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

493

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

16

2025.12.31

关闭win10系统自动更新教程大全
关闭win10系统自动更新教程大全

本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

12

2025.12.31

阻止电脑自动安装软件教程
阻止电脑自动安装软件教程

本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

5

2025.12.31

html5怎么使用
html5怎么使用

想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

2

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
布尔教育燕十八mysql高级视频教程
布尔教育燕十八mysql高级视频教程

共24课时 | 7.5万人学习

Go 中文开发手册
Go 中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号