gpt4 book ai didi

java.sql.SQLException : Numeric Overflow while using IN operator

转载 作者:行者123 更新时间:2023-12-04 04:57:38 27 4
gpt4 key购买 nike

我实现了一个 Java 应用程序,它使用以下查询根据给定的 id 集查询数据库:

select * from STUDENT where ID in (?)

这组 id 将用于替换 ? .但是,偶尔,我会收到一个异常:
Caused by: java.sql.SQLException: Numeric Overflow
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.DatabaseError.throwSqlException(DatabaseError.java:445)
at oracle.jdbc.driver.NumberCommonAccessor.throwOverflow(NumberCommonAccessor.java:4319)
at oracle.jdbc.driver.NumberCommonAccessor.getInt(NumberCommonAccessor.java:187)
at oracle.jdbc.driver.OracleResultSetImpl.getInt(OracleResultSetImpl.java:712)
at oracle.jdbc.driver.OracleResultSet.getInt(OracleResultSet.java:434)

经过一些测试,我意识到如果我将 id 列表分成许多较小的子列表,异常就会停止发生。出于某种原因,jdbc 不喜欢在 IN (?) 中放入太多值。 .我想知道是否有人以前见过这个问题并对此有解释?由于此问题从未发生在生产环境中,而仅发生在本地环境中(资源较少),因此我怀疑它与服务器资源有关。

谢谢

更新:我使用的源代码是:
// create a query
private String getQueryString(int numOfParams) {
StringBuilder out = new StringBuilder();
out.append("select * from STUDENT where ID in (");
for (int i = 0; i < numOfParams; i++) {
if (i == numOfParams - 1) {
out.append("?");
} else {
out.append("?, ");
}
}
out.append(")");
}

// set parameters
private void setParams(PreparedStatement ps, Set<String> params) {
int index = 1;
for (String param: params) {
ps.setString(index++, param);
}
}

public void queryStudent(Connection conn, Set<String> ids) throws Exception {
String query = this.getQueryString(ids.size());
PreparedStatement ps = conn.prepareStatement(query);
this.setParams(ps, ids);
ps.executeQuery();

// do some operations with the result
}

最佳答案

该问题是由 GlassFish 和应用程序之间的 ojdbc 驱动程序冲突引起的。为了修复它,我需要:

  • 更新应用程序的 pom.xml(因为我使用的是 maven)以使用最新的
    ojdbc 即 ojdbc6-11.2.0.3
  • 将 ojdbc6-11.2.0.3 添加到 GlassFish 库
  • 如有必要,从 glassfish 中部署的应用程序库中手动删除 ojdbc jar(显然这不会被取消部署清除)
  • 关于java.sql.SQLException : Numeric Overflow while using IN operator,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16569578/

    27 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com