JAVA调用oracle存储过程返回游标出现“对象不再存在”问题

运行在was5.1上的应用某个功能在DAO中调用存储过程返回游标时出现“java.sql.SQLException: ORA-08103: 对象不再存在”的错误,
系统开发框架:spring+hibernate+struts
系统运行环境:jdk1.5+wabsphere5.1+oracle9i
以下是调用存储过程的JAVA代码和过程内容

callableStatement = connection.prepareCall("CALL GET_GRADE(?,?,?,?,?)");

callableStatement.setObject(1, parameterArray.getOracleARRAY(connection));
callableStatement.registerOutParameter(2, OracleTypes.CURSOR);
callableStatement.registerOutParameter(3, OracleTypes.NUMBER);
callableStatement.registerOutParameter(4, OracleTypes.VARCHAR);
callableStatement.execute();

if (callableStatement.getInt(3) != 0) {
String error = callableStatement.getString(5);
throw BaseException.systemException("系统错误!" + error);
}

resoultSet = (ResultSet) callableStatement.getObject(2);
if (logger.isDebugEnabled()) {
logger.debug("tree execute before");
}

执行到callableStatement.getObject(2)就出错了。

PROCEDURE GET_STANDARDGRADE(
P_PARAMETERLIST IN OUT TYPE_PARAMETERLIST,
P_HEAD OUT T_CURSOR, -- 返回游标
P_B_EXCEPTION IN OUT NUMBER, -- =0:正常 非0 错误
P_B_EXCEPTION_DESCRIPTION IN OUT VARCHAR2) -- 错误描述
IS
W_SQLSTR LONG;
W_SUBQUERYSTRING LONG;
W_D_COLUMNSTRING LONG;

W_LOOPPOINT NUMBER := 0;
W_NAME VARCHAR2(30);
W_YEAR NUMBER;
CURSOR W_CURSOR IS
SELECT GID,NAME
FROM GRADE
WHERE YEAR = W_YEAR
ORDER BY GID;
W_CURSOR_ROW W_CURSOR%ROWTYPE;
BEGIN
P_B_EXCEPTION := -1;
W_YEAR := PKG_PARAMETER.FNC_GETINTVALUEBYNAME('YEAR',P_PARAMETERLIST,1);

IF P_HEAD%ISOPEN THEN
CLOSE P_HEAD;
END IF;

delete from TMPTAB_RPT_TITLE;
--临时表插入两行数据
INSERT INTO TMPTAB_RPT_TITLE(ID,PID,COLUMNNAME)
VALUES(2,NULL,'NAME');
INSERT INTO TMPTAB_RPT_TITLE(ID,PID,COLUMNNAME)
VALUES(1,NULL,'STDID');
--获取临时表数据,返回游标
OPEN P_HEAD FOR SELECT * FROM TMPTAB_RPT_TITLE ORDER BY ID;
P_B_EXCEPTION := 0;
<<PROCEDURE_EXIT>>
P_B_EXCEPTION := P_B_EXCEPTION +0;
END GET_STANDARDGRADE;


CREATE GLOBAL TEMPORARY TABLE YSBZ.TMPTAB_TREE_CONTAINER
(
ID VARCHAR2(100),
PID VARCHAR2(100),
COLUMNNAME VARCHAR2(100)
)
ON COMMIT DELETE ROWS
NOCACHE
/


奇怪的是hibernate连接方式如果是DatasourceConnection会出现以上的错误,改成DriverManagerConnection方式运行又是正常的。
后来怀疑是临时表的问题,将ON COMMIT DELETE ROWS改成ON COMMIT PRESERVE ROWS
后问题解决了。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值