免费注册 查看新帖 |

Chinaunix

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

perl怎么调用oracle存储过程? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-08-31 14:33 |只看该作者 |倒序浏览
请问有谁知道perl怎么调用oracle存储过程?谢谢!
DBI中,把sql语句直接改为 "exec 存储过程名" 就行了吗?我试过报invalid SQL statement

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
2 [报告]
发表于 2006-08-31 16:55 |只看该作者
最後要加 ";"......

论坛徽章:
0
3 [报告]
发表于 2006-08-31 17:25 |只看该作者

回复 2楼 apile 的帖子

这是我的程序内容,
my $sql1=qq{exec sync_content (623);};
my $cate = $dbh->prepare($sql1) or die "Can't prepare statement: $DBI::errstr";
my $rc = $cate->execute;

后台还是报DBD::Oracle::st execute failed: ORA-00900: invalid SQL statement (DBD ERROR: OCIStmtExecute) [for Statement "exec sync_content (623);"]

这个语句到底怎么写呀,弄了一天,也没结果!

论坛徽章:
0
4 [报告]
发表于 2006-08-31 19:47 |只看该作者

回复 3楼 cary 的帖子

Hallo,

"exec sync_content (623);" is correct SQL syntax in Oracle?
If yes, can you execute this SQL direct under Oracle's shell? and what's happend?
Generally BDI sent SQL with $dbh->prepare(SQL) to database, the SQL syntax must
be available in this database.

regards, ulmer

论坛徽章:
0
5 [报告]
发表于 2006-09-01 15:12 |只看该作者

回复 1楼 cary 的帖子

谢谢ulmer 和 apile ! 问题已经搞定,
my $sql1=qq{begin sync_content(?,?); end;};
my $cate = $dbh->prepare($sql1) or die "Can't prepare statement: $DBI::errstr";
my $rc = $cate->execute($sort,$i_cate_id);

论坛徽章:
0
6 [报告]
发表于 2006-09-01 17:24 |只看该作者
原帖由 cary 于 2006-9-1 15:12 发表
谢谢ulmer 和 apile ! 问题已经搞定,
my $sql1=qq{begin sync_content(?,?); end;};
my $cate = $dbh->prepare($sql1) or die "Can't prepare statement: $DBI::errstr";
my $rc = $cate->ex ...


Congraduation!
That is why I have indicated the SQL synatx here!

论坛徽章:
0
7 [报告]
发表于 2006-09-01 17:47 |只看该作者
Informix:
$statement = <<"EOF";
        EXECUTE PROCEDURE xxx_procedure()
EOF

Oracle:
$statement = <<"EOF";
                BEGIN xxx_procedure();END;
EOF
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP