免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4419 | 回复: 8
打印 上一主题 下一主题

关于存储过程调用的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-02-04 18:11 |只看该作者 |倒序浏览
1可用积分
foreach select branch into Vbranch from jigou
      call  myproc(Vbranch) returning n;
end foreach
上面的语句执行后,myproc仅把foreach 搜寻出的第一个值作为参数执行了一次后退出了,branch应该有很多值得,但是都不能执行到。
是不是foreach中不能循环执行存储过程呀?

最佳答案

查看完整内容

可以在存储过程中再调存储过程的。请加 with hold。

论坛徽章:
0
2 [报告]
发表于 2008-02-04 18:11 |只看该作者
可以在存储过程中再调存储过程的。请加 with hold。

论坛徽章:
0
3 [报告]
发表于 2008-02-05 09:16 |只看该作者
加trace语句调试了一下,在myproc之前的可以打印出来,但是在紧跟myproc之后的就打印不出,真是搞不明白。

论坛徽章:
0
4 [报告]
发表于 2008-02-05 12:57 |只看该作者
call  myproc(Vbranch) returning n;
只是把myproc()过程的结果放入n变量。并不返回值。

试试
return   myproc(Vbranch) with resume ;

还可以
       call  myproc(Vbranch) returning n;
           return n with resume;

[ 本帖最后由 wenlq 于 2008-2-5 13:01 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2008-02-05 13:10 |只看该作者
好像不行吧,在这里执行“return myproc(Vbranch) with recume;”的话,就直接返回,退调用过程了吧。我试了,由于外层声明的返回值为三个,所以报错,编译不过去。您好像误会我的意思了,我是想让myproc(Vbranch)可以被循环调用,但是它只是执行循环的第一个值,也就是只执行了一次就退出调用过程了。没有按我的设想循环的被调用。

[ 本帖最后由 cabbage_rose 于 2008-2-5 13:15 编辑 ]

论坛徽章:
0
6 [报告]
发表于 2008-02-05 13:19 |只看该作者
如果仅仅是 这3句
foreach select branch into Vbranch from jigou
      call  myproc(Vbranch) returning n;
end foreach
n应该取到 最后一个值。

论坛徽章:
0
7 [报告]
发表于 2008-02-05 13:39 |只看该作者
myproc(Vbranch) 实际上是一个过程,我不是为的要它的返回值,返回值仅仅是表达存储过程成功与失败的。myproc过程中要对数据做一些处理的,你是不是以为调用myproc是为了得到它的返回值呀?我的表述可能不太清楚。

论坛徽章:
0
8 [报告]
发表于 2008-02-07 22:54 |只看该作者
在foreach中加with hold后,可以执行
感谢wenlq和cloudflashes的帮助

论坛徽章:
0
9 [报告]
发表于 2008-02-12 22:13 |只看该作者

with hold 加在哪个地方

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP