【数据库BUG】Caused by: java.io.IOException: Tried to send an out-of-range integer as a 2-byte value

本文介绍了一个在使用PostgreSQL数据库时遇到的问题,即IN子句中参数过多导致的错误,并提供了通过分批查询来解决问题的具体方法。

问题描述:

数据库是pgsql,在进行查询操作时,使用了in(xxx,xxx,...),结果因为in里面的参数太多了导致报错

问题原因

当你使用JDBC组装预执行语句的时候,参数的数量是有一个限制的,限制的大小就是2个byte的整数的大小,也就是32767,当超过这个大小的时候你就会看到上面的错误。这是因为PostgreSQL客户端/后端协议规定从客户端发送到PostgreSQL后端的参数的数量为2个byte的integer。
在这里插入图片描述

解决办法

当时采用的最直接的解决办法是,分批次查询,然后把查询结果塞到列表里面。

当使用 PostgreSQL 的 JDBC 驱动进行数据库操作时,可能会遇到 `java.io.IOException: Tried to send an out-of-range integer as a 2-byte value` 的异常。该异常通常发生在尝试发送一个超出 2 字节整数范围(即超出 -32768 到 32767 的范围)的整数值时,尤其是在执行大规模数据插入或批量操作时[^1]。 此问题的根本原因在于 PostgreSQL 客户端/后端协议规定参数的数量必须是 2 字节整数的大小,即最多 32767 个参数。当使用 JDBC 组装预执行语句时,如果参数数量超过这个限制,就会触发该异常。例如,当使用 `PreparedStatement` 或批量插入时,每个参数都会被当作一个单独的条目发送,当总数超过 32767 时,就会抛出该错误[^2]。 ### 解决方案 #### 1. 分批次处理数据 为了规避此限制,可以将数据分批次处理,确保每次发送的参数数量不超过 32767。例如,在使用 `SqlSession` 执行批量插入时,可以设置每次提交的条数,并在达到阈值时提交事务,避免参数数量超过限制: ```java public void insertToResultExcel(List<Map<String, Object>> paramList) { SqlSession batchSqlSession = null; try { System.err.println("插入的数据量有---------->" + paramList.size()); batchSqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH, false); int batchSize = 10000; for (int i = 0; i < paramList.size(); i++) { Map<String, Object> map = paramList.get(i); PointDomain pointDomain = Map2Bean.map2Bean(map, PointDomain.class); batchSqlSession.getMapper(SuanFaMapper.class).insert(pointDomain); if (i % batchSize == 0 && i != 0) { batchSqlSession.commit(); } } batchSqlSession.commit(); } catch (Exception e) { e.printStackTrace(); } finally { if (batchSqlSession != null) { batchSqlSession.close(); } } } ``` 通过这种方式,可以有效避免参数数量超过 2 字节整数限制的问题[^4]。 #### 2. 避免使用大量参数的 SQL 语句 在构建 SQL 语句时,应尽量避免构造包含大量 `VALUES(...)` 的插入语句,因为每个值都会被视为一个单独的参数。例如,当插入大量数据时,可以使用 `COPY` 命令或使用文件导入的方式替代直接的 `INSERT` 操作,以减少参数数量[^3]。 #### 3. 升级 PostgreSQL JDBC 驱动 某些 PostgreSQL JDBC 驱动版本可能对此限制进行了优化或调整。建议使用最新版本的驱动,以确保兼容性和性能的提升。 ### 总结 `java.io.IOException: Tried to send an out-of-range integer as a 2-byte value` 是由于 PostgreSQL 协议限制导致的常见问题。通过合理控制参数数量、分批次处理数据、优化 SQL 构造方式以及升级驱动版本,可以有效解决此问题。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值