我收到以下异常:

java.lang.ClassCastException: org.apache.commons.dbcp.DelegatingStatement cannot be cast to org.apache.tomcat.dbcp.dbcp.DelegatingStatement
    optimise.database.ProdigyDB.doInsertSerial(ProdigyDB.java:139)
    optimise.stock.CurrentRequest.writeRequest(CurrentRequest.java:145)
    optimise.stock.SubmitOrderServlet.processRequest(SubmitOrderServlet.java:51)
    optimise.stock.SubmitOrderServlet.doPost(SubmitOrderServlet.java:188)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
    optimise.stock.AuthFilter.doFilter(AuthFilter.java:69)

代码行是这样的:
 serial = ((com.informix.jdbc.IfmxStatement) ((org.apache.tomcat.dbcp.dbcp.DelegatingStatement) statement).getDelegate()).getSerial();

完整的功能是这样的:
public static int doInsertSerial(String sql) {
    int serial = 0;

    try {
        Connection connection = getConnection();
        java.sql.Statement statement = connection.createStatement();
        statement.executeUpdate(sql);

        serial = ((com.informix.jdbc.IfmxStatement)((org.apache.tomcat.dbcp.dbcp.DelegatingStatement) statement).getDelegate()).getSerial();

        statement.close();
        connection.close();
    } catch (SQLException e) {
        throw new RuntimeException("SQL Update Exception\n" + sql, e);
    }

    return serial;
}

这很神秘,因为当在Unix SCO5服务器上部署相同的代码时可以正常工作,而在Linux Red Hat服务器上则出错。

任何帮助深表感谢。

谢谢。

深入研究,我发现DelegatingStatement类显示错误:

公共(public)类DelegatingStatement扩展了AbandonedTrace实现的声明{

org.apache.commons.dbcp.DelegatingStatement不是抽象的,并且不会覆盖java.sql.Statement中的抽象方法isPoolable()

我不明白为什么会这样。

最佳答案



该软件包对于DelegatingStatement类是不同的。 org.apache.commons.dbcporg.apache.tomcat.dbcp.dbcp是两个不同的包,提供了两个不同的DelegatingStatement类。之所以得到ClassCastException,是因为JVM根本看不到它们是同一类型。

检查已导入的DelegatingStatement类包。根据代码org.apache.tomcat.dbcp.dbcp包应该被导入。

还要检查thisthis

10-08 14:14