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

时间:2013-02-14 16:31:22

标签: 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();

如果我一次使用调试器和第一行,一切顺利。如果我不使用它并只运行应用程序,我会得到这个例外:

 [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)

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

3 个答案:

答案 0 :(得分:0)

st.setInt(2, "de Niro");替换为st.setString(2, "de Niro");

答案 1 :(得分:0)

关于提供的代码段只有几点。

  1. st.setInt(2,“de Niro”);
    在这里,您将“string”设置为查询的第二个参数,但您使用了setInt()方法,那是不正确的。

  2. 是否与您的操作系统有关。我的意思是你使用64位寡妇操作系统和32位连接器。我不确定。

  3. 检查此链接。 "[Microsoft][ODBC Driver Manager] Invalid string or buffer length" error

答案 2 :(得分:0)

最佳解决方案是停止使用sun包(Why Developers Should Not Write Programs That Call 'sun' Packages)中的此类。此驱动程序也很旧,它是一个在ODBC调用中转换JDBC调用的类型1驱动程序。

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

同样根据这个documentation,这个桥将在JDK8中删除,因此如果你想要一个便携/适应性的解决方案,那么使用它是个坏主意。