急!急!急!有会DB2游标的进来呀!

秀HAPPY 2010-05-06 04:03:52
各位大哥,大姐:
小妹,近期有个需求,需要用到DB2的游标,希望大哥大姐们指教。
数据库的存储量为每天300000条数据,我需要查询其规定的三个月内的条数,并给循环做另外的操作。同事说用游标做比较好,但是游标,小妹从来没有接触过,想问一下各位有没有例子或学习资料,供我参考。小妹将不剩感激!
...全文
422 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
B-A-I 2010-05-18
  • 打赏
  • 举报
回复
谁说游标一定要写在存储过程中,完全可以在你的应用程序中进行声明.
EXEC SQL DECLARE CUR1 FOR
SQL STATEMENT
END-EXEC
即可.不知楼主是什么语言的程序.
shangboerds 2010-05-13
  • 打赏
  • 举报
回复
yes
秀HAPPY 2010-05-13
  • 打赏
  • 举报
回复
游标必须写在存储过程中吗?那位高手可以给我解答呀!
shangboerds 2010-05-11
  • 打赏
  • 举报
回复
光使用游标是解决不了问题的,你应该使用DB2 SQL PL,我的博客有大量的文章,希望的你有帮助:http://blog.csdn.net/shangboerds/archive/2010/01/13/5185044.aspx
秀HAPPY 2010-05-11
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 zhpsam109 的回复:]
注意 commit和rollback
使用游标时要特别注意如果没有加with hold 选项,在Commit和Rollback时,该游标将被关闭。Commit 和Rollback有很多东西要注意。特别小心

游标的两种定义方式
一种为
declare continue handler for not found
begin
set v_notfound = 1;
end……
[/Quote]
再请教个初级问题,游标必须写在存储过程中吗?可不可以使用嵌套游标呀!本人没有接触过,谢谢您了!
yangxiao_jiang 2010-05-07
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 zhpsam109 的回复:]

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

游标的两种定义方式
一种为
declare continue handler for not found
begin
set v_notfound = 1;
……
[/Quote]
太详细了,难道是老师?
王帆 2010-05-07
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 zhpsam109 的回复:]

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

游标的两种定义方式
一种为
declare continue handler for not found
begin
set v_notfound = 1;
……
[/Quote]
很详细,楼主认真看看。
zhpsam109 2010-05-06
  • 打赏
  • 举报
回复
注意 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除外)一起使用。
秀HAPPY 2010-05-06
  • 打赏
  • 举报
回复
没人理我呀!不是吧!高手来解决呀!

5,889

社区成员

发帖
与我相关
我的任务
社区描述
IBM DB2 是美国IBM公司开发的一套关系型数据库管理系统,它主要的运行环境为UNIX(包括IBM自家的AIX)、Linux、IBM i(旧称OS/400)、z/OS,以及Windows服务器版本
社区管理员
  • DB2
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧