选择合适的游标类型

背景:

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

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

因为动态游标会消耗资源去检查基础表的更新, 所以对于复杂的查询, 且不需要反映基础表更新情况的游标处理中, 将游标定义为静态的。另外,还有一种 KEYSET 类型的游标,它的行为介于动态和静态游标之间。

 

在笔者遇到的一个案例中, 使用动态游标的处理会花费分钟, 而改为静态游标后, 处理时间只需要1 秒钟, 效率的差异非常明显

 

另外, 在使用 DYNAMIC 游标的时候, 必须注意“行的数据值、顺序和成员身份在每次提取时都会更改”的问题。

下面是一个看似正常, 但实际执行会造成死循环的示例

SET NOCOUNT ON

-- 建立测试环境

DECLARE @tb TABLE(

    id int

        PRIMARY KEY)

INSERT @tb(

    id)

SELECT id = 1 UNION ALL

SELECT id = 2

 

-- 游标处理

DECLARE tb CURSOR LOCAL FAST_FORWARD

FOR

SELECT id FROM @tb

DECLARE @id int

OPEN tb

FETCH tb INTO @id

WHILE @@FETCH_STATUS = 0

BEGIN

    PRINT @id

    UPDATE @tb SET

        id = id + 2

    WHERE id = @id

    FETCH tb INTO @id

END

CLOSE tb

DEALLOCATE tb

 
  • 0
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
你可以使用以下方法来判断 Oracle 游标是否有数据: 1. 使用游标的 FETCH 命令来尝试获取数据。如果 FETCH 命令成功执行并返回数据,那么游标中有数据;如果 FETCH 命令未返回任何数据,那么游标中没有数据。 例如,你可以使用以下代码片段来判断游标是否有数据: ```sql DECLARE my_cursor SYS_REFCURSOR; my_record my_table%ROWTYPE; BEGIN OPEN my_cursor FOR SELECT * FROM my_table; FETCH my_cursor INTO my_record; IF my_cursor%FOUND THEN DBMS_OUTPUT.PUT_LINE('Cursor has data'); ELSE DBMS_OUTPUT.PUT_LINE('Cursor is empty'); END IF; CLOSE my_cursor; END; ``` 注意,在这个例子中,`my_table` 代表你的表名,`my_cursor` 是游标变量,`my_record` 是记录类型变量。`FETCH my_cursor INTO my_record` 语句尝试从游标中获取一条数据,并将其存储在 `my_record` 变量中。`my_cursor%FOUND` 条件用于判断是否成功获取到数据。 2. 使用游标的 ROWCOUNT 属性来获取游标中的数据行数。如果 ROWCOUNT 的值大于零,则表示游标中有数据;否则,游标中没有数据。 例如,你可以使用以下代码片段来判断游标是否有数据: ```sql DECLARE my_cursor SYS_REFCURSOR; my_count NUMBER; BEGIN OPEN my_cursor FOR SELECT * FROM my_table; FETCH my_cursor BULK COLLECT INTO my_table_array; my_count := my_cursor%ROWCOUNT; IF my_count > 0 THEN DBMS_OUTPUT.PUT_LINE('Cursor has data'); ELSE DBMS_OUTPUT.PUT_LINE('Cursor is empty'); END IF; CLOSE my_cursor; END; ``` 在这个例子中,`my_table` 代表你的表名,`my_cursor` 是游标变量,`my_table_array` 是记录类型的数组变量。`FETCH my_cursor BULK COLLECT INTO my_table_array` 语句尝试从游标中获取全部数据,并将其存储在 `my_table_array` 变量中。然后,通过 `my_cursor%ROWCOUNT` 获取游标中的数据行数,如果大于零,则表示游标中有数据。 这些是判断 Oracle 游标是否有数据的两种常见方法。根据你的具体需求和代码逻辑,选择适合的方法即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值