java – Prepared语句仅在不调试时抛出异常
发布时间:2020-12-15 03:11:09 所属栏目:Java 来源:网络整理
导读:我使用这段代码将一些数据插入数据库: Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");Connection con=DriverManager.getConnection("jdbc:odbc:war_odbc");PreparedStatement st = con.prepareStatement( "INSERT INTO Actors(FirstName,LastName,Age) VA
我使用这段代码将一些数据插入数据库:
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位. 解决方法
最好的解决方案是停止使用sun package(
Why Developers Should Not Write Programs That Call ‘sun’ Packages)中的这个类.此驱动程序也很旧,它是一个在ODBC调用中转换JDBC调用的类型1驱动程序.
现在几乎所有的DB供应商都实现了类型4驱动程序此驱动程序实现将JDBC调用直接转换为特定于供应商的数据库协议. 同样根据这个documentation,这个桥将在JDK8中删除,所以如果你想要一个便携/适应性的解决方案,使用它是个坏主意. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容