jdbc - createArrayOf AbstractMethodError

标签 jdbc c3p0

我正在尝试使用 java 代码向 postgres 插入一个数组,但我总是收到此错误:

SEVERE [http-nio-8080-exec-2]org.apache.catalina.core.StandardWrapperValve.invoke Servlet.service()
 for servlet [] in context with path [/] threw exception 
[Servlet execution threw an exception] with root cause
 java.lang.AbstractMethodError: 
com.mchange.v2.c3p0.impl.NewProxyConnection.createArrayOf(Ljava/lang/String;[Ljava/lang/Object;)Ljava/sql/Array;

使用的代码
pst = getConnection().prepareStatement(INSERT_QUERY,PreparedStatement.RETURN_GENERATED_KEYS);
        pst.setString(1, t.getname());
        pst.setString(2, t.getEmail());
        Array itemIds = conn.createArrayOf("bigint", t.getItemIds());
        pst.setArray(3, itemIds);

如果我通过主类运行该函数,它工作正常,但在部署到 tomcat 服务器后,http 调用失败并出现上述错误。
  • 使用的数据库 - Postgres
  • JDBC 驱动程序 postgres-9.1-901-1.jdbc4
  • c3p0-0.9.5-pre10
  • tomcat-8.0.24

  • 根据我所做的研究, createArrayOf() 应该与 jdbc4 和 c3p0-0.9.5 一起使用。

    使用这个工作正常,但我不认为它是正确的方法
            if (conn instanceof C3P0ProxyConnection) {
                C3P0ProxyConnection proxy = (C3P0ProxyConnection) conn;
                try {
                 Method m = Connection.class.getMethod("createArrayOf", String.class, Object[].class);
                 Object[] args = { "bigint", t.getItemIds() };
                 itemIds = (Array) proxy.rawConnectionOperation(m, C3P0ProxyConnection.RAW_CONNECTION, args);
                } catch (IllegalArgumentException e) {
                    throw new SQLException(e);
                }
             } else {
                    itemIds = conn.createArrayOf("bigint", t.getItemIds());
             }
    

    需要帮忙 。
    谢谢

    最佳答案

    我强烈怀疑您的应用程序的有效 CLASSPATH 中某处有一个旧版本的 c3p0。我已经从 Maven Central 上的 c3p0-0.9.5-pre10.jar 和 c3p0-0.9.5.1.jar 下载并验证了 com.mchange.v2.c3p0.impl.NewProxyConnection实际上包含 createArrayOf方法。

    % javap -sysinfo -cp ./c3p0-0.9.5.1.jar com.mchange.v2.c3p0.impl.NewProxyConnection
    Classfile jar:file:/Users/swaldman/tmp/c3p0jars/c3p0-0.9.5.1.jar!/com/mchange/v2/c3p0/impl/NewProxyConnection.class
      Last modified Jun 16, 2015; size 27098 bytes
      MD5 checksum c1ff36b87219ddc84c92fb6c1445a2d1
      Compiled from "NewProxyConnection.java"
    public final class com.mchange.v2.c3p0.impl.NewProxyConnection implements java.sql.Connection,com.mchange.v2.c3p0.C3P0ProxyConnection {
       //...
       public synchronized java.sql.Array createArrayOf(java.lang.String, java.lang.Object[]) throws java.sql.SQLException;
       //...
    }
    

    虽然这不太可能是您的问题的原因,但我建议您升级到 c3p0-0.9.5.1 而不是使用预发布版本。

    要查看您的应用程序实际使用的 c3p0 版本,请查看日志文件中的 INFO,以了解初始化 c3p0 库时打印的横幅。它应该是这样的:
    INFO: Initializing c3p0-0.9.5.1 [built 16-June-2015 00:06:36 -0700; debug? true; trace: 10]
    

    我怀疑你会看到一个旧版本,在某个地方,也许在传递依赖中,你正在引入 0.9.1.x 或 0.9.2.x 版本的库。

    祝你好运!

    关于jdbc - createArrayOf AbstractMethodError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32770550/

    相关文章:

    java - 如何从jsp页面中删除数据库记录?

    java - ResultSet.TypeForwardOnly 和 Result Set.Type Scrollable 之间的区别

    java - HikariCP - 在连接 checkin 和从连接池 checkout 时动态设置连接的数据库

    java - 尝试使用 Spring WebFlow 在 Hibernate 中配置 c3p0 池

    hibernate - 如何捕获c3p0和JPA异常?

    jdbc - Squirrel 客户端连接到 Phoenix - 超时异常

    java - 如何将文本字段和密码字段与字符串值进行比较?

    Java 表观死锁

    java - 不再与 c3p0 建立联系

    java - 使用外部 jar 。找不到适用于 jdbc :sqlserver 的合适驱动程序