原创文章,转载必需注明出处:http://www.ncloud.hk/%E6%8A%80%E6%9C%AF%E5%88%86%E4%BA%AB/introduce-for-sqlserver-cursor-2/

上一节我们简单讲解了SqlServer的游标的简单创建,本节我们将根据msdn上的创建游标代码来详细讲解游标的创建、以及其特性。

 DECLARE cursor_name CURSOR [ LOCAL | GLOBAL ]
[ FORWARD_ONLY | SCROLL ]
[ STATIC | KEYSET | DYNAMIC | FAST_FORWARD ]
[ READ_ONLY | SCROLL_LOCKS | OPTIMISTIC ]
[ TYPE_WARNING ]
FOR select_statement
[ FOR UPDATE [ OF column_name [ ,...n ] ] ]
[;]

一、创建游标

(a)、LOCAL 和GLOBAL

就像C#或C++等编程语言一样,使用sql语言创建游标也可以创建全局游标和局部游标。Local意味着游标的声明周期在函数获得存储过程中是可用的,Global意味着游标全局有效。如果不指定游标作用域,默认作用域为Global

如下:

 declare @table Table(Id int)
declare @i int=0
while @i<100
begin
insert into @table values(@i)
set @i=@i+1;
end declare My_Cursor1 cursor global for select * from @table
declare My_Cursor2 cursor local for select * from @table
declare My_Cursor3 cursor for select * from @table go
open My_Cursor1
open My_Cursor2
open My_Cursor3

(b)、 FORWARD_ONLY 和 SCROLL

游标是针对数据集的,那么它在读取数据集的时候就有其读取数据的方向。 FORWARD_ONLY意味着游标只能从数据集开始向数据集结束的方向读取,FETCH NEXT是唯一的选项,而SCROLL支持游标在定义的数据集中向任何方向,或任何位置移动,如下:

 --不加参数默认为forward_only
declare My_Cursor1 cursor for select * from @table
declare My_Cursor2 cursor forward_only for select * from @table
declare My_Cursor3 cursor scroll for select * from @table open My_Cursor1
open My_Cursor3
open My_Cursor3 fetch last from My_Cursor1
fetch last from My_Cursor2
fetch last from My_Cursor3

(c)、[ STATIC | KEYSET | DYNAMIC | FAST_FORWARD ]

[ READ_ONLY | SCROLL_LOCKS | OPTIMISTIC ]

至于上面几种情况笔者也不是太了解,就先跳过介绍

二、打开游标

创建完成游标后我们还要打开游标才能正确的使用游标:代码如下:

 open My_Cursor1
open My_Cursor3
open My_Cursor3

三、使用游标

使用游标分为两部分:一是操作游标的指向,二是操作游标指向的数据行。

游标支持使用6中指向操作。分别是:第一行(first),最后一行(LAST),下一行(next),上一行(prior),直接跳到某一行(absolute(n)),相对于目前跳几行(relative(n)),代码如下:

 --指定参数scroll后方可使用6种游标指向参数,对于未指定scroll参数的则默认读取下一行数据
declare @id int
declare My_Cursor cursor scroll for select * from @table
open My_Cursor
--指向下一行数据
fetch next from My_Cursor into @id
--指向上一行数据
fetch prior from My_Cursor into @id
--指向第一行数据
fetch first from My_Cursor into @id
--指向最后一行数据
fetch last from My_Cursor into @id
--直接跳转到某行数据
fetch absolute 12 from My_Cursor into @id
--相对于目前来说上两行数据
fetch relative -2 from My_Cursor into @id

游标经常会和全局变量@@FETCH_STATUS与WHILE循环来共同使用,以达到遍历游标所在数据集的目的,例如:

 declare @id int
declare My_Cursor cursor scroll for select * from @table
open My_Cursor
--指向下一行数据
fetch next from My_Cursor into @id
while @@FETCH_STATUS=0
begin
select @id
End

四、关闭游标

游标使用完后必须要关闭,代码如下:

close My_Cursor

五、释放游标

当游标不再需要被使用后,释放游标。代码如下:

deallocate My_Cursor

SqlServer之游标深入的更多相关文章

  1. SqlServer 利用游标批量更新数据

    SqlServer 利用游标批量更新数据 Intro 游标在有时候会很有用,在更新一部分不多的数据时,可以很方便的更新数据,不需要再写一个小工具来做了,直接写 SQL 就可以了 Sample 下面来看 ...

  2. 【SqlServer】SqlServer的游标使用

    什么是游标 结果集,结果集就是select查询之后返回的所有行数据的集合. 游标则是处理结果集的一种机制吧,它可以定位到结果集中的某一行,多数据进行读写,也可以移动游标定位到你所需要的行中进行操作数据 ...

  3. SQLServer中游标是如何处理数据的?

    游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次以行或者多行前进或向后浏览数据的能力.我们可以把游标当作一个指针,它可以指定结果中的任何位置,然后允许 ...

  4. Sqlserver 关于游标

    对于sql来说查询的思维方式的面向集合对于游标来说:思维方式是面向行的 性能上:游标会吃更多内存,减少可见的并发,锁定资源等 当穷尽了while循环,临时表,表变量,自建函数,或其他方式仍然无法实现某 ...

  5. sqlserver 使用游标过程中出现的错误

    下面的见解是在使用游标的过程中做的日记.我也是第一次使用,如果有什么不对的地方请批评指正,大家一起努力. 1. 消息 16951,级别 16,状态 1,过程 usp_proc,第 16 行      ...

  6. SQLServer中游标实例介绍(转)

    引言 我们先不讲游标的什么概念,步骤及语法,先来看一个例子: 表一 OriginSalary                      表二 AddSalary 现在有2张表,一张是OriginSal ...

  7. SQLserver 存储过程游标使用

    ALTER PROCEDURE [dbo].[p_DeleteStretchData] ) , ) AS BEGIN ) ) declare @stretch_cursor cursor -- 声明游 ...

  8. 使用sqlserver的游标功能来导数据的常见写法

    一定要自己试过才知道么? 你也没试过吃屎,你怎么知道屎不能吃,难道你试过啊...(没有愤怒的意思) ),),) declare cursor_data CURSOR FOR SELECT [UserN ...

  9. sqlserver 存储过程 游标实例

    if exists(select * from sysobjects where id = object_id(N'dbo.test_cursor') and type = 'P') drop PRO ...

随机推荐

  1. 软件工程——PairProject

    结对编程组员: 马辰     11061178 柴泽华  11061153 1)    照至少一张照片, 展现两人在一起合作编程的情况. 结对编程的优点 1)在编程过程中,任何一段代码都不断地复审,同 ...

  2. Web Service学习之八:Soap消息详解

    一.区别概念 WSDL是网络服务描述语言,是XML文档:它包含一系列描述某个web service的定义或者说是规则.尤其是定义了传输Sope消息的结构 Soap:简单对象访问协议,是交换数据的一种协 ...

  3. build.gradle 使用tips

    7.查看依赖 gradlew [你想查看的module]:dependencies >dependencies.txt 6.buildToolsVersion build tools版本号 co ...

  4. 什么是USBMini接口

    USB的接口有四种.一种是大头,有A型和B型两种,其中A型最常见,就是我们用的最多的标准的USB接头:一种是小头的,也就是USB Mini,也有A型和B型两种,其中B型应用最多,主要应用于手机.MP4 ...

  5. codeforces 651B Beautiful Paintings

    B. Beautiful Paintings time limit per test 1 second memory limit per test 256 megabytes input standa ...

  6. [iOS 多线程 & 网络 - 1.2] - 多线程GCD

    A.GCD基本使用 1.GCD的概念 什么是GCD全称是Grand Central Dispatch,可译为"牛逼的中枢调度器"纯C语言,提供了非常多强大的函数GCD的优势GCD是 ...

  7. CodeForces 706B Interesting drink (二分查找)

    题意:给定 n 个数,然后有 m 个询问,每个询问一个数,问你小于等于这个数的数有多少个. 析:其实很简单么,先排序,然后十分查找,so easy. 代码如下: #pragma comment(lin ...

  8. K - 最少拦截系统

    Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不 能超过前一发的高度.某天,雷达 ...

  9. 高扩展的基于NIO的服务器架构

    当你考虑写一个扩展性良好的基于Java的服务器时,相信你会毫不犹豫地使用Java的NIO包.为了确保你的服务器能够健壮.稳定地运行,你可能会花大量的时间阅读博客和教程来了解线程同步的NIO selec ...

  10. ios 调试

    http://www.cnblogs.com/weilaikeji/p/3306597.html http://www.cnblogs.com/Twisted-Fate/p/4760156.html ...