7

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

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),我成功地测试了它。

4

3 回答 3

0

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

于 2013-02-14T16:32:46.703 回答
0

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

  1. st.setInt(2, "德尼罗");
    在这里,您将“字符串”设置为查询的第二个参数,但您使用了 setInt() 方法,这是不正确的。

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

检查此链接。 “[Microsoft][ODBC Driver Manager] 无效的字符串或缓冲区长度”错误

于 2013-02-14T17:17:27.707 回答
0

最好的解决方案是停止使用包中的此类sunWhy Developers Should Not Write Programs That Call 'sun' Packages)。此外,这个驱动程序真的很老,它是一个类型 1 驱动程序,可以将 JDBC 调用转换为 ODBC 调用。

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

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

于 2013-02-15T11:03:09.480 回答