• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
鱼要的是海洋,鸟要的是天空,我要的是自由!
平凡的人不平凡的人生
博客园    首页    新随笔    联系   管理    订阅  订阅

认识静态与动态游标

背景:

静态(STATIC)游标创建将由该游标使用的数据的临时复本。对游标的所有请求都从tempdb 中的这一临时表中得到应答;因此,在对该游标进行提取操作时返回的数据中不反映对基表所做的修改,并且该游标不允许修改

动态(DYNAMIC) 游标会反映在滚动游标时对结果集内的各行所做的所有数据更改。行的数据值、顺序和成员身份在每次提取时都会更改。动态游标不支持ABSOLUTE 提取选项。

不指定STATIC 关键字的时候, 默认定义的游标是动态(DYNAMIC) 的

如果很在意游标的类型, 应该在定义游标的时候, 加上游标类型定义的关键字, 并加上TYPE_WARNING 关键字, 以便在游标类型不是预期的情况下, 收到警告信息

 

演示:

下面的演示针对 STATIC 和DYNAMIC 游标, 显示两者在游标循环期的差异

-- 定义演示数据

IF OBJECT_ID('tempdb..#tb') IS NOT NULL

    DROP TABLE #tb

CREATE TABLE #tb(

    id int PRIMARY KEY,

    col sysname)

INSERT #tb(

    id, col)

SELECT 1, 'AA' UNION ALL

SELECT 2, 'BB' UNION ALL

SELECT 3, 'CC' UNION ALL

SELECT 4, 'DD'

 

-- 游标测试

DECLARE CUR_tb CURSOR LOCAL FORWARD_ONLY READ_ONLY TYPE_WARNING DYNAMIC--STATIC

FOR          

SELECT

    id, col

FROM #tb

 

-- 游标打开前删除记录

DELETE TOP (1)

FROM #tb

WHERE id = 4

SELECT 'before cursor open', * FROM #tb

 

-- 打开游标

OPEN CUR_tb

 

-- 游标打开后删除记录

DELETE TOP (1)

FROM #tb

WHERE id = 3

SELECT 'after cursor open', * FROM #tb

FETCH CUR_tb

WHILE @@FETCH_STATUS = 0

BEGIN

    -- 游标循环中删除记录

    DELETE TOP (1)

    FROM #tb

    WHERE id = 2

 

    FETCH CUR_tb

END

CLOSE CUR_tb

DEALLOCATE CUR_tb

posted @ 2007-06-29 14:35  伊凡  阅读(658)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3