Prepared语句仅在不调试时抛出异常

Jac*_*son 7 java eclipse

我使用这段代码将一些数据插入数据库:

Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
Connection con=DriverManager.getConnection("jdbc:odbc:war_odbc");
PreparedStatement st =
   con.prepareStatement(
      "INSERT INTO Actors(FirstName,LastName,Age) VALUES(?,?,?)" );
st.setString(1, "Robert");
st.setString(2, "de Niro");
st.setInt(3,45);
st.executeUpdate();     
con.close();
Run Code Online (Sandbox Code Playgroud)

如果我一次使用调试器和第一行,一切顺利.如果我不使用它并只运行应用程序,我会得到以下异常:

 [Microsoft][ODBC Driver Manager] Invalid string or buffer length
    at sun.jdbc.odbc.JdbcOdbc.createSQLException(Unknown Source)
    at sun.jdbc.odbc.JdbcOdbc.standardError(Unknown Source)
    at sun.jdbc.odbc.JdbcOdbc.SQLGetDataString(Unknown Source)
    at sun.jdbc.odbc.JdbcOdbcResultSet.getDataString(Unknown Source)
    at sun.jdbc.odbc.JdbcOdbcResultSet.getString(Unknown Source)
    at sun.jdbc.odbc.JdbcOdbcConnection.buildTypeInfo(Unknown Source)
    at sun.jdbc.odbc.JdbcOdbcConnection.initialize(Unknown Source)
    at sun.jdbc.odbc.JdbcOdbcDriver.connect(Unknown Source)
    at java.sql.DriverManager.getConnection(Unknown Source)
    at java.sql.DriverManager.getConnection(Unknown Source)
Run Code Online (Sandbox Code Playgroud)

我使用的是Windows 7 64位.我去了管理工具,数据源(ODBC),我成功测试了它.

ala*_*inm 0

最好的解决方案是停止使用包中的此类sun为什么开发人员不应编写调用“sun”包的程序)。而且这个驱动程序确实很旧,它是一个类型 1 驱动程序,用于将 JDBC 调用转换为 ODBC 调用。

现在几乎所有的DB厂商都实现了Type 4驱动程序。该驱动程序实现将 JDBC 调用直接转换为特定于供应商的数据库协议。

另外根据这个文档,这个桥将在 JDK8 中被删除,所以如果你想要一个可移植/适应性强的解决方案,那么使用它是个坏主意。