在PB中用游标循环插入到一个表中数据,但是结果只插入一条数据。具体代码:

dowhiletruefetchmycurinto:temp_xm;ifsqlca.sqlcode<>0thenexit;insertintojh_pd(pdhm,brx... do while true

fetch mycur into :temp_xm;
if sqlca.sqlcode <> 0 then exit;
insert into jh_pd(pdhm,brxm) values(1,:temp_xm);
commit;
loop
temp_xm有多条数据,但是插到jh_pd中,只插进去第一条数据。
展开
 我来答
rico1800
推荐于2016-03-03 · 超过46用户采纳过TA的回答
知道小有建树答主
回答量:73
采纳率:0%
帮助的人:96.6万
展开全部
问题出在commit,如果后面为空,PB语法默认为commit using sqlca;
如果提交成功,sqlca.sqlcode=0,就退出循环了。
解决方法有2个
1)先全部执行完毕插入操作后,再统一提交,也就是将commit放置在do while ...loop循环后面
2) 另创建一个链接如mysqlca,链接参数与sqlca一样,提交时使用commit using mysqlca;
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式