我将我的Java EE应用程序从Java 1.4迁移到Java 6,并从OC4J迁移到WebLogic 10.3.3。我遇到了一个存储过程调用问题,它在OC4J上的Java 1.4中工作,但不再适用于WebLogic上的Java 6。存储过程定义如下所示:
create or replace procedure sp_report
(
/* snip 68 parameters */
rs OUT pkg_recordset.rs_ref_cursor
)
AS ...其中rs_ref_cursor是:
type rs_ref_cursor is Ref CURSOR;我的java代码如下所示:
public final static String CALL_REPORT = "{call SP_REPORT"
+ "(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,"
+ "?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)}";
...
DriverManager.registerDriver (new oracle.jdbc.OracleDriver());
conn = DriverManager.getConnection("jdbc:oracle:thin:@[server]:[port]:[sid]", "[username]", "[password]");
cstmt = conn.prepareCall(CALL_ALPHA_REPORT);
/* set 68 other parameters */
cstmt.registerOutParameter("rs", OracleTypes.CURSOR);
...在调用registerOutParameter时,这总是会导致此异常:
SQL Exception: 17004: Invalid column type: 246
java.sql.SQLException: Invalid column type: 246
at oracle.jdbc.driver.SQLStateMapping.newSQLException(SQLStateMapping.java:70)
at oracle.jdbc.driver.DatabaseError.newSQLException(DatabaseError.java:133)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:199)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:263)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:271)
at oracle.jdbc.driver.OracleStatement.getInternalType(OracleStatement.java:3532)
at oracle.jdbc.driver.OracleCallableStatement.registerOutParameterInternal(OracleCallableStatement.java:127)
at oracle.jdbc.driver.OracleCallableStatement.registerOutParameterInternal(OracleCallableStatement.java:2181)
at oracle.jdbc.driver.OracleCallableStatement.registerOutParameter(OracleCallableStatement.java:2094)
at oracle.jdbc.driver.OracleCallableStatementWrapper.registerOutParameter(OracleCallableStatementWrapper.java:1593)
...我试过的一些事情都会导致相同的错误:
从Oracle网站从ojdbc14.jar切换到ojdbc6.jar
从weblogic的lib文件夹从ojdbc14.jar切换到ojdbc6.jar
使用WebLogic控制台中定义的JDBC连接(Thin和Thin XA驱动程序)
使用java.sql.Types.OTHER而不是OracleTypes.CURSOR(虽然Oracle异常之后的数字从246更改为1111)
在设置其他68个参数之前,将registerOutParameter语句移至
上述各种组合
谢谢你的帮助。