Zeal Blog - 泽欧里
梦想 就像鸡蛋
要么孵化 要么臭掉
WWW Zeal Blog

ORA-01003 no statement parsed

zeal 2005-08-23 11:05 于 JAVA/C++ , 1585 字 |  + 0 - 0   English
Made In Zeal 转载请保留原始链接:http://www.zeali.net/entry/150
标签 ( Tags ):  ,  ,  ,  , 
Weblogic+jdbc+Oracle。当应用服务器运行的时候重新编译某个被调用的存储过程,调用程序出现 ORA-01003 no statement parsed 错误。

Oracle官方文档的错误解释如下:

Cause: A host language program call referenced a cursor with no associated parsed SQL statement. A SQL call (for example, OSQL3) must be used to pass a SQL statement to Oracle and to associate the statement with an open cursor. A cursor must already have an associated SQL statement if referenced in any of the following calls: DESCRIBE, NAME, DEFINE, BIND, EXECUTE, and FETCH.

Action: Do the SQL call, for example, OSQL, to pass the required SQL statement before referencing the cursor.

但既然只是重新编译了一下,肯定不会是存储过程的语法有问题。greenflute认为这个问题与Weblogic无关,像Package, Procedure, Prepared statement之类的东西通过jdbc调用的时候,Oracle会把预编译之后的结果保存在自身的Cache之中,当你重新编译了存储过程以后,这些Cache中的东西变成无效,导致Oracle抛出ORA-01003错误。只有重新建立新的Oracle会话(即重新建立数据库连接)或者dba通过命令强制清除Cache才能解决这个问题。

对于Weblogic来说,由于采用了数据库连接池来访问数据库,连接将被保持,因而Cache不会被清除。最直接的解决方法:重启Weblogic应用服务器。如果不想重启Weblogic的话,似乎只能在Oracle管理后台里面强制drop所有来自Weblogic服务器的数据库会话--确切地说都不算是很好的解决方案。但对于已经上线的应用来说,类似存储过程之类的东西也不应该是频繁进行改动的;如果是开发环境,那么不用想太多,重启Weblogic吧。

这是目前为止对这个问题的调查结论。期待以后能找到更明确的解释。让我感到奇怪的是我以前自己写的独立的应用程序也用过各种各样的连接池,也用了很多的存储过程,也曾经在运行的过程中重新编译过,但好像还没有碰到过这个问题,只在Weblogic中碰到了。

Update: 托technorati的福,在和本文相关的Tags里面偶然看到一篇日志Improving JDBC performance with Statement caching,突然想到Weblogic的Connection Pool确实是可以对常规的数据库连接做些手脚的。这个 StatementCacheSize 参数就是设置来对所有通过Pool产生的PreparedStatement/CallableStatement 进行Cache。对于存储过程的调用当然也就在其Cache之列了。赶紧让WangWei去做对这个猜测进行测试。

解决办法:要么禁用Weblogic Connection Pool的Statement caching功能,要么不要对在线的存储过程进行修改。

This Entry was Last Modified on 2007-05-25 22:13
引用本文(TrackBack): 此功能无限期关闭ing ... 如有引用请在文中标明出处并提供超链接  
没有评论.
对于这篇日志您有什么想法?我想听听您的高见。
如果您不是没有思想的机器Spammer,请告诉我 4 + 8 =
然后任选以下两种方式之一告诉我您的身份:
1. 使用您的 OpenID
2. 使用传统留言格式
(必填) 名字
如何称呼您?
(选填) URL
在此填写您的 Blog / Homepage 的地址,我将非常乐于访问
(选填) Email
Email地址将在经过防SPAM处理后显示在页面。如果您不希望公开自己的Email,请略过此栏
并写下您的见解:
(由于需要进行SPAM过滤,如果评论提交速度慢请耐心等待)
记住我?

  如何进行评论                   当有新回复时给我发送邮件通知
除了 <b> 和 <i> 之外,其他的HTML标签都将从您的评论中去除. URL 或 Email 地址会被自动加上链接.
当您点击发表或者预览之后,系统会自动保存您此次评论的内容,以便当网络原因发表失败时直接按Ctrl-V重新粘贴上次评论内容。
注意:快捷键及自动拷贝功能仅对IE浏览器有效。
发贴统计

Tot 611/1320

日志存档
2008年
2007年
2006年
本 Blog 原创内容
遵循以下授权:

Creative Commons
(创作共用) CC

署名-非商业性
-相同方式分享
Zeal Blog 基于
Powered byPivot - 1.24.1: 'Arcee'
Pivot1.24.1
开发
Launched @
2005-04-27
 里,居也。——《说文》    里,邑也。——《尔雅》。李注:“居之邑也。”沪ICP备05024379号 Back To Home All Links Loading