博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java.sql.SQLException: Prepared or callable statement has more than 2000 parameter markers及解决方案...
阅读量:5316 次
发布时间:2019-06-14

本文共 1650 字,大约阅读时间需要 5 分钟。

1. 问题

     最近在项目中修bug的时候,碰到这样一个错误:

Caused by: java.sql.SQLException:Prepared or callable statement has more than 2000 parameter markers.    at net.sourceforge.jtds.jdbc.SQLParser.parse(SQLParser.java:1139)    at net.sourceforge.jtds.jdbc.SQLParser.parse(SQLParser.java:156)    at net.sourceforge.jtds.jdbc.JtdsPreparedStatement.
(JtdsPreparedStatement.java:107)Caused by: java.sql.SQLException:Prepared or callable statement has more than 2000 parameter markers.

     出错的代码简化如下(list中的元素个数可能大于2000):

1 SELECT * FROM xxx x  2          WHERE x.date <= :today AND x.id IN (:list)

2. 收获

     起初并不明白是什么情况,经过一番google加请教之后,有一些收获。项目中用的JTDS的driver版本为1.2.4,数据库为SQL Server。在该driver的源码中找到如下一个片段(在net.sourceforge.jtds.jdbc.SQLParser类中):

     从这段代码中可以看出,其实这并不是一个bug,而是work as designed。我们得到的另一个信息是,对于不同类型的数据库,不同的版本之间,这种约束是有差别的,分别是255,1000,2000。这样看来,之前的查询语句出错也就很好理解了,在IN子句中的参数个数多于2000是肯定会抛异常的。

3. 解决方案

     主要有两种解决方案:一种是优化SQL语句,一种是优化查询逻辑(即分批处理)。

     对于第一种方案,如果IN子句中的参数来自于另一张表的话,可以考虑类似如下的查询方式:

1 SELECT * FROM xxx x2          INNER JOIN yyy y ON x.id = y.id   3          WHERE x.date <= :today

     对于第二种方案,分批来查询速度没有第一种快,但是不用修改SQL语句。

1         List
result = Lists.newArrayList();2 List
> partitionIds = Lists.partition(ids, BATCH_SIZE);3 for (List
partitionId : partitionIds) {4 param.put("list", partitionId);5 List
resultItems = xxxService.query(param);6 result.addAll(resultItems);7 }8 return result;

     这种方案的劣势在于速度上会有损失,但是可以从Java代码的逻辑层避免上面的问题。

     希望这些对大家有所帮助。

 

 

 

转载于:https://www.cnblogs.com/penghongwei/p/3603872.html

你可能感兴趣的文章
js如何查看元素类型
查看>>
mysql复习
查看>>
A标签跳转链接并修改样式
查看>>
深入Java集合学习系列:ConcurrentHashMap之实现细节
查看>>
Pycharm下将py文件打包成exe文件
查看>>
tomcat一闪而过
查看>>
本周ASP.NET英文技术文章推荐[03/25 - 03/31]
查看>>
本周ASP.NET英文技术文章推荐[09/30- 07/13]:.NET Framework、JSON、Google Analytics、文件上传、GridView、IIS 7、Web开发...
查看>>
详解go语言的array和slice 【二】
查看>>
父元素 高度固定,如何使其中的文字垂直居中?
查看>>
汉三水属国(北地属国、安定属国)
查看>>
JS设置文本框只能是数字和小数点。
查看>>
struts2 标签不能使用EL 表单式
查看>>
spark-2.1.0 集群安装
查看>>
idea-spark-sbt 打包jar
查看>>
hdu 4493 Tutor (水 精度)
查看>>
Linux0.11内核剖析--内核体系结构
查看>>
vi is failed with error "E382: Cannot write, 'buftype' option is set" in Linux
查看>>
pageadmin CMS网站建设教程:站点添加自定义字段
查看>>
Hello, AnnsShadow!
查看>>