报错:[Microsoft][ODBC 驱动程序管理器] 无效的字符串或缓冲区长度

这篇具有很好参考价值的文章主要介绍了报错:[Microsoft][ODBC 驱动程序管理器] 无效的字符串或缓冲区长度。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

  1. 问题描述
    执行到 preparedStatement.setObject(1, “1111”);
    出现报错 :[Microsoft][ODBC 驱动程序管理器] 无效的字符串或缓冲区长度
    无效的字符串或缓冲区长度,microsoft,java,开发语言
  2. 解决方法
	// preparedStatement.setObject(1, "1111");		// 会报错 [Microsoft][ODBC 驱动程序管理器] 无效的字符串或缓冲区长度

	// 改成 setBytes() 的方式
	preparedStatement.setBytes(1, "111很好看".getBytes(StandardCharsets.UTF_16LE));
  1. 原因分析
    具体什么原因也不清楚,大概就是:不使用Object等类型,改用 bytes 字节数组。

    因为Jdk 1.6/7在64位操作系统上JDBC-ODBC桥上的Bug,导致在调用ResultSet.getObject()/getString()的时候随机并且不定时的报出 [Microsoft][ODBC 驱动程序管理器] 无效的字符串或缓冲区长度 这个错误。并不是一定会报错,可能是正常的运行了一段时间之后才报出来。

    出处:https://blog.51cto.com/u_15127605/4234309

4.简单完整的 demo

        // 加载驱动
        Class.forName("org.objectweb.rmijdbc.Driver").newInstance();
        // 连接 Connection 
        Connection connection = DriverManager.getConnection(url);
        // 预编译 PreparedStatement 
        PreparedStatement preparedStatement = connection.prepareStatement("insert into triode (part_number,name) values (?,?)");
        // 改成 setBytes() 的方式
        preparedStatement.setBytes(1, "111很好看".getBytes(StandardCharsets.UTF_16LE));
        // StandardCharsets.UTF_16LE   乱码的话,再试试其它的
        preparedStatement.setBytes(2, "222靠路口".getBytes(StandardCharsets.UTF_16LE));
		preparedStatement.addBatch();
		preparedStatement.executeUpdate();
		// 关闭操作
        if (preparedStatement != null) {
            preparedStatement.close();
        }
        if (connection != null) {
            connection.close();
        }

参考文章:关于PreparedStatement.addBatch()方法
https://blog.csdn.net/blueling51/article/details/6928755文章来源地址https://www.toymoban.com/news/detail-569333.html

到了这里,关于报错:[Microsoft][ODBC 驱动程序管理器] 无效的字符串或缓冲区长度的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包