zoukankan      html  css  js  c++  java
  • 游标的简单理解

    游标:游标提供了一种对从表中检索出的数据进行操作的灵活手段,就本质而言,游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。游标总是与一条SQL 选择语句相关联因为游标由结果集(可以是零条、一条或由相关的选择语句检索出的多条记录)和结果集中指向特定记录的游标位置组成。当决定对结果集进行处理时,必须声明一个指向该结果集的游标。

    声明游标:

    --先看SCROLL,游标的语句格式如下

    语句格式为:
    DECLARE 游标名称 [INSENSITIVE] [SCROLL]
    CURSOR FOR select
    语句
    [FOR{READ ONLY|UPDATE[OF
    列名字表]}]

    这里用的SCROOL,不作深究,

            INSENSITIVE
      定义一个游标,以创建将由该游标使用的数据的临时复本。对游标的所有请求都从 tempdb 中的该临时表中得到应答;
      因此,在对该游标进行提取操作时返回的数据中不反映对基表所做的修改,并且该游标不允许修改。使用 SQL-92 语法时,
      如果省略 INSENSITIVE,(任何用户)对基表提交的删除和更新都反映在后面的提取中。
       SCROLL
      指定所有的提取选项(FIRST、LAST、PRIOR、NEXT、RELATIVE、ABSOLUTE)均可用。
      如果在 SQL-92 DECLARE CURSOR 中未指定 SCROLL,则 NEXT 是唯一支持的提取选项。
      如果指定 SCROLL,则不能也指定 FAST_FORWARD CURSOR固定语法

    DECLARE curTmpTaskCursor SCROLL CURSOR FOR

                                (

                                                   SELECT

                                                   DprojectName,

                                                   DDemolitionName,

                                                   DPlacementArea                       

                                                   FROM @pt_tbDemolition

                                )

    --打开游标

                                OPEN curTmpTaskCursor

    --@@CURSOR判断当前打开的游标中符合条件的行的数目是否大于0,成立就执行下面的语句

                                IF @@CURSOR_ROWS > 0

                                BEGIN

    --简单理解一下FETCH:

    --FETCH FIRST:提取游标的第一行。
    --FETCH NEXT:提取上次提取的行的下一行。
    --FETCH PRIOR:提取上次提取的行的前一行。
    --FETCH LAST:提取游标中的最后一行。
    --FETCH ABSOLUTE n:
    -- 如果n 为正整数,则提取 游标中的第n行
    -- 如果n为负整数,则提取游标最后一行之前的第n行
    -- 如果n 为0,则不提取任何行
    --FETCH RELATIVE n :
    -- 如果n为正,则提取上次提取的行之后的第n行。
    -- 如果n为负,则提取上提取的行之前的第n行。
    -- 如果n为0,则再次提取同一行

    这里的FETCH NEXT就是提取下一行

                                         FETCH NEXT FROM  curTmpTaskCursor INTO      

                                         @pt_ProjectName ,

                                         @pt_DemolitionName ,

                                         @pt_PlacementArea

                                         WHILE @@FETCH_STATUS = 0

                                         BEGIN

                                         --计算每个拆迁户有多少房子

                                                   if @pt_PlacementArea is null

                                                   begin

                                                   set @pt_SmallHouse=0

                                                   set @pt_MiddleHouse=0

                                                   set @pt_BigHosue=0

                                                   end

                                                   .

                                                   .

                                                   .

                                                   .

                                                   [语句自由发挥]

                                                   FETCH NEXT FROM  curTmpTaskCursor INTO

                                                   @pt_ProjectName ,

                                                   @pt_DemolitionName ,

                                                   @pt_PlacementArea                                  

                                         END

                                END

    --关闭游标               

                       CLOSE curTmpTaskCursor

    --删除游标语句

                       DEALLOCATE curTmpTaskCursor

    参考:http://blog.csdn.net/ztj111/article/details/4133122

               http://www.cnblogs.com/qiaojun/articles/1486365.html

  • 相关阅读:
    Win7下的DragDrop事件不触发?
    灵巧多叉树 IAgileMultiTree -- ESBasic 可复用的.NET类库(23)
    ESFramework 4.0 快速上手(01) -- Rapid引擎
    多叉树 IMultiTree -- ESBasic 可复用的.NET类库(22)
    Round缓存管理器RoundCacheManager--ESBasic 可复用的.NET类库(26)
    遵循Spring大纲的XML(反)序列化 SpringFox --ESBasic 可复用的.NET类库(27)
    如何自动以管理员身份运行.NET程序?
    音频数据编解码——在.NET中使用Speex(附下载)
    离线消息如何实现?-- ESFramework 4.0 快速上手(02)
    浅谈黑客攻击
  • 原文地址:https://www.cnblogs.com/howie/p/2550801.html
Copyright © 2011-2022 走看看