zoukankan      html  css  js  c++  java
  • 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除外)一起使用。


     

  • 相关阅读:
    如何用C语言写一个基于服务器和客户端(TCP)
    如何把C++的源代码改写成C代码?
    可自定义的超链接控件
    一个XP风格的下拉分离按钮
    GroupControl
    带有工具提示和/或位图资源的按钮
    动态更改按钮图像
    一键启用/禁用一组控件
    粘性Snap-to-Center控制
    WinForm ImageButton
  • 原文地址:https://www.cnblogs.com/millen/p/2267339.html
Copyright © 2011-2022 走看看