Oracle JDBC中的ArrayIndexOutOfBoundsException

时间:2012-12-03 12:38:45

标签: jdbc oracle11g

我在oracle jdbc驱动程序中遇到一个奇怪的异常。本机方法如何抛出OutOfBounds异常?我认为它与其中一个专栏中的blob有关。

我们使用solaris x86,sun java 6,websphere作为我们的服务器。数据库是oracle 11和ojdbc 5。

使用Windows XP的本地配置一切正常。

有什么想法吗?

java.lang.ArrayIndexOutOfBoundsException
at oracle.jdbc.driver.T2CStatement.t2cDefineFetch(Native Method)
at oracle.jdbc.driver.T2CPreparedStatement.doDefineFetch(T2CPreparedStatement.java:1020)
at oracle.jdbc.driver.T2CPreparedStatement.fetch(T2CPreparedStatement.java:1252)
at oracle.jdbc.driver.OracleResultSetImpl.close_or_fetch_from_next(OracleResultSetImpl.java:373)
at oracle.jdbc.driver.OracleResultSetImpl.next(OracleResultSetImpl.java:277)

在代码中我没什么特别的。创建预准备语句,填写参数并执行查询。

                preparedStatement = connection.prepareStatement(queryAsString);
                preparedStatement.setObject( [some paramters...] );

                ResultSet result = preparedStatement.executeQuery();

                result.setFetchSize(100);
                while (result.next()) {
                    int count = Fields.getFieldsCount();
                    Object[] objects = new Object[count];
                    for (int j = 0; j < count; ++j) {
                        Object object = result.getObject(j + 1);
                        objects[j] = object;
                    }
                    list.add(objects);
                }
                result.close();

但是我不认为这个问题出现在java代码中,因为相同的代码确实可以在java 5上使用ojdbc14和sparc solaris。我想这更像是一种配置。

0 个答案:

没有答案