- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个问题困扰了我好几个小时,但我无法找到发生这种情况的确切原因?在使用 ResultSet.next() 迭代存储过程的 refcursor out 参数时,我收到 java.sql.SQLSyntaxErrorException: ORA-01722: invalid number 。令我困扰的是,即使实际上没有结果可供迭代,它也会发生。
存储过程的签名:
PROCEDURE GET_PROG_SRCH_BY_CRITERIA
(p_orgID IN NUMBER,
p_MEPID IN NUMBER,
p_prog_prg_id IN NUMBER,
p_pcom_enrol_date IN VARCHAR2,
p_pcom_enrol_year_from IN VARCHAR2,
p_pcom_enrol_year_to IN VARCHAR2,
p_pcom_non_prtcm_date IN VARCHAR2,
p_pcom_completion_date IN VARCHAR2,
p_pcom_status_code IN VARCHAR2,
p_sys_cursor OUT SYS_REFCURSOR
);
Java 代码片段:
statement = connection.prepareCall("call PROG_TOOLS.GET_PROG_SRCH_BY_CRITERIA(?,?,?,?,?,?,?,?,?,?)");
statement.setLong(1, searchCriteria.getOrganizationID());
/*
* Code to Set other 8 Parameters comes here
*/
statement.registerOutParameter(10, oracle.jdbc.OracleTypes.CURSOR);
statement.executeQuery();
resultSet = (ResultSet) statement.getObject(10);
/*
* Code to Initialize necessary value Objects comes here
*/
while (resultSet.next()) {
/*
* Code to get values from resultSet using column named index
* and initialize value objects
* Few example:
*/
dataVO = new DataVO();
dataVO.setPcomID(result.getLong("PCOM_ID"));
dataVO.setPersonID(result.getLong("PERSON_ID"));
.
.
programList.add(dataVO);
}
问题:如果我通过在第三个参数中发送 NULL 来调用 GET_PROG_SRCH_BY_CRITERIA,我会得到预期的结果。如果我通过在第三个参数中发送实际值来调用 GET_PROG_SRCH_BY_CRITERIA,则会在行上收到 java.sql.SQLSyntaxErrorException: ORA-01722: invalid number
while (resultSet.next()) {
异常跟踪:
java.sql.SQLSyntaxErrorException: ORA-01722: invalid number
at oracle.jdbc.driver.SQLStateMapping.newSQLException(SQLStateMapping.java:91)
at oracle.jdbc.driver.DatabaseError.newSQLException(DatabaseError.java:112)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:173)
at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:455)
at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:413)
at oracle.jdbc.driver.T4C8Oall.receive(T4C8Oall.java:1030)
at oracle.jdbc.driver.T4CStatement.doOall8(T4CStatement.java:183)
at oracle.jdbc.driver.T4CStatement.fetch(T4CStatement.java:1000)
at oracle.jdbc.driver.OracleResultSetImpl.close_or_fetch_from_next(OracleResultSetImpl.java:314)
at oracle.jdbc.driver.OracleResultSetImpl.next(OracleResultSetImpl.java:228)
at weblogic.jdbc.wrapper.ResultSet_oracle_jdbc_driver_OracleResultSetImpl.next(Unknown Source)
at org.app.ejb.program.dao.ProgDAO.searchProgEnrollees(ProgDAO.java:136)
我通过使用 SQLDeveloper 工具直接测试该过程来检查该过程,方法是发送与上述 Java 代码使用的相同参数。它工作得非常好。
我尝试使用 OJDBC14 和 OJDBC6 驱动程序,但没有成功。
我不知道为什么在 resultSet.next() 上会发生这种情况。如果第三个参数为空,那么我不会收到此异常,并且流程按预期工作。
非常感谢这里的任何帮助。
使用的技术: - Java 6、ejb - Oracle 11g 数据库 R2 (11.2.0.3) - Oracle Weblogic 10g (10.3.0)
最佳答案
也许您需要先对包含的 ResultSet 调用 next() ?
statement.registerOutParameter(10, oracle.jdbc.OracleTypes.CURSOR);
ResultSet rs1 = statement.executeQuery();
rs1.next();
resultSet = (ResultSet) statement.getObject(10);
关于refcursor 上的 java.sql.SQLSyntaxErrorException : ORA-01722: invalid number while resultSet. next() 我不明白为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31271586/
在我的应用程序中,我必须获取记录并将它们放入二维数组中。我必须首先触发两个查询以找出计数,以便我可以初始化数组,其次是获取数据。它会导致性能下降。我需要提高性能的解决方案。 谢谢。 最佳答案 I ha
在 Zend Framework 应用程序中,它的构建与 ZF2 Getting Started tutorial 中的相册应用程序非常相似,我使用 ResultSet 对象将数据从模型通过 Cont
我是 java 和 SQL 新手,我重复了一个我不知道如何避免的问题: 假设我想创建两个executeQuery,一个在另一个内部,在getRequestsFromDB方法中我创建第一个execute
这个问题已经有答案了: Why should I call close() on a ResultSet and Connection instance? (4 个回答) 已关闭 7 年前。 使用完结
public List searchCourse(String name) { List list = null; Course course = null;
我正在使用两个不同的查询从两个表中选择数据。我正在使用一个连接和一个结果集。两个表都已填充,但第二个查询的 resultset.next() 返回 false,尽管它必须为 true。 我还尝试使用两
试图了解这里发生了什么。 DatabaseMetaData 返回一个空结果集,而实际上相同的 SQL 查询则不会。这不是主要问题,因为我使用第二个代码示例作为解决方法。 DatabaseMetaDat
假设我有多个结果集(每个结果集将引用数据库中的 1 行)(它们属于同一个表。)。现在我想创建合并的结果集,它将实习生拥有所有其他结果集。所以我的主要目标是创建一个组合的 ResultSet,它将指向以
我正在尝试将 influxdb 与我的应用程序集成并处理输出。我正在导入 InfluxDBClient 包以连接到在我的本地计算机上运行的 influx 实例。使用以“influxdb.results
我正在尝试创建一个框架来显示数据库中的所有电影名称,然后他们选择框架中的一行来执行另一个查询。 我有一个 ResultSet (rs),它接收查询执行的结果以选择电影名称。之后,我使用 SQLTabl
我有一个 Servlet,它使用返回 ResultSet 的静态实用程序方法。 在我的 Servlet 代码中,我有 ResultSet rs = SimpleSearch.searchByName(
在从 Postgres 或 Oracle 检索时间戳时(我们称之为 startDate),使用 resultSet.getString("startDate") 调用或 resultSet.getTi
全部, 对于名为Analyze 的类及其构造函数Analyze,该构造函数将Java JDBC Resultset 对象作为参数。 private Resultset analysisSet publ
m 尝试遍历 3 个结果集并比较它们的值。 bt 它抛出这个异常......有人可以帮助我了解我正在经历的地方吗?这是一段代码: java.lang.Object[] reconciledPaymen
我已经尝试使用谷歌搜索并在 SO 上查看了这些线程: java jdbc accessing multiple resultsets Open two resultsets simultaneousl
我在 SQLite 的 JDBC 驱动程序中遇到问题。 我正在使用 SELECT 语句执行查询。 如果我得到一个空的 ResultSet(0 行),那么我会在调用 getString(1) 时看到抛出
我正在尝试根据特定条件搜索表格。在 SQL Developer 中执行时,SQL 查询返回正确的结果(1 行)。在 JDBC 中,resultset 不为 null,但 resultset.next(
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
我正在尝试在 Java 应用程序中处理大量数据。数据存储在 MySQL 数据库中,我使用的是 jdbc 连接器 8.0.11。 我的问题是我需要多次访问每条记录并且再次执行查询需要太多时间。使用 Re
这个问题已经有答案了: Getting java.sql.SQLException: Operation not allowed after ResultSet closed (2 个回答) 已关闭
我是一名优秀的程序员,十分优秀!