• DB2中游标的使用(转)


    转自:http://hi.baidu.com/zhuyuehua/blog/item/cc23b48b6d62f2729e2fb481.html

    注意 commit和rollback
    使用游标时要特别注意如果没有加with hold 选项,在Commit和Rollback时,该游标将被关闭。Commit 和Rollback有很多东西要注意。特别小心

    游标的两种定义方式
    一种为
    declare continue handler for not found
       begin
       set v_notfound = 1;
       end;

    declare cursor1 cursor with hold for select market_code from tb_market_code for update;
    open cursor1;
    set v_notfound=0;
    fetch cursor1 into v_market_code;
    while v_notfound=0 Do
    --work
    set v_notfound=0;
    fetch cursor1 into v_market_code;
    end while;
    close cursor1;
    这种方式使用起来比较复杂,但也比较灵活。特别是可以使用 with hold 选项。如果循环内有commit或rollback 而要保持该cursor不被关闭,只能使用这种方式。

    另一种为
       pcursor1: for loopcs1 as cousor1 cursor as
    select market_code as market_code
       from tb_market_code
       for update
       do
       end for;
       这种方式的优点是比较简单,不用(也不允许)使用 open,fetch,close。
    但不能使用with hold 选项。如果在游标循环内要使用commit,rollback则不能使用这种方式。如果没有commit或rollback的要求,推荐使用这种方式(看来For这种方式有问题)。

    修改游标的当前记录的方法
    update tb_market_code set market_code='0' where current of cursor1;
    不过要注意将cursor1定义为可修改的游标
    declare cursor1 cursor for select market_code from tb_market_code
    for update;

    for update 不能和 GROUP BY、 DISTINCT、 ORDER BY、 FOR READ ONLY及UNION, EXCEPT, or INTERSECT 但 UNION ALL除外)一起使用。


     

  • 相关阅读:
    ajax获取值的两种方法
    java反射
    idea 方便的设置代码段
    jstl核心标签库
    git遇到的问题 .Git: There is no tracking information for the current branch.
    java使用顺序存储实现队列
    RabbitMQ基本操作
    springboot 如何操作redis
    docker遇到的问题以及docker 操作镜像的基本操作
    教你在 Yii2 中添加全局函数
  • 原文地址:https://www.cnblogs.com/millen/p/2267339.html
Copyright © 2020-2023  润新知