关于informix的rowid问题,请大侠解决,谢谢!

yang0411 2003-01-23 12:42:22
RS/6000 AIX 环境下 Esql:
请教各位大侠:

程序的流程是这样的,
EXEC SQL DECLARE rs10_cur CURSOR FOR
SELECT rowid,*
FROM rspf10
WHERE ... FOR UPDATE;

EXEC SQL OPEN rs10_cur;

for(;;) {
EXEC SQL FETCH rs10_cur INTO :VSrowid,:Rspf10;
if (SQLCODE == SQLNOTFOUND) break;
if (SQLCODE != 0) return 300;

strcpy(Rspf10.rs10acno,PP1030);

EXEC SQL UPDATE rspf10 SET *=(:Rspf10)
WHERE rowid = :VSrowid;
}

表中只有一条记录,当修改成功后,循环并未退出,而是将修改后的记录又
读了出来,循环了两次。
...全文
262 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
powerman_lyj 2003-02-10
  • 打赏
  • 举报
回复
建议先读出具体行数进行for循环,这涉及到informix固有性质造成的。
dgmzf 2003-02-10
  • 打赏
  • 举报
回复
建议不用rowid,在定义游标的时候已经使用了FOR UPDATE语句,则后面更新的时候可以用EXEC SQL UPDATE rspf10 SET *=(:Rspf10) where CURRENT OF rs10_cur 。
prghome 2003-02-01
  • 打赏
  • 举报
回复
不用游标,直接用update不好吗?
update rspf10 set rs10acno = :Rspf10;
wooe 2003-01-31
  • 打赏
  • 举报
回复
建议设一个flag来标注记录成功更新的情况,用一个技术起来纪录循环次数,show出来以便解决问题。

rowid可以视为每一纪录的unique查询条件,但单位里资深informixer讲,在多个磁盘阵列的server上,会有问题。。。

在库表的批量update操作中,如达到目的最好加强制exit.

cooth 2003-01-30
  • 打赏
  • 举报
回复
不要用for,用while就没问题了!

1,195

社区成员

发帖
与我相关
我的任务
社区描述
其他数据库开发 Informix
社区管理员
  • Informix社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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