解决mybatis in语句不能大于1000的问题
来源:互联网 发布:压缩json 编辑:程序博客网 时间:2024/05/23 22:46
Java开发中会出现一种情况,就是使用mybatis 的in语句的时候,in语句里面的数组大小不能大于1000.
可以通过以下方法解决:
对于一个List<String> ids 大小大于1000的list而言,使用getSumArrayList方法,获取List<List<String>> 对象
List<List<String>> idParams = shareEpdService.getSumArrayList(idParam); Map<String, Object> mapNew = new HashMap<>(); mapNew.put("ids", idParams ); settlementCostMapper.submitDataByCondition(mapNew)调用mybatis的方法,做如下处理:
<update id="submitDataByCondition">UPDATE 表名 SET STATE=1 WHERE STATE IN (-1,0) <foreach collection="ids" item="idsItem"> and id in <foreach collection="idsItem" item="id" open="(" separator="," close=")"> #{id} </foreach> </foreach></update>
getSumArrayList方法如下:
public <T> List<List<T>> getSumArrayList(List<T> list){ List<List<T>> objectlist = new ArrayList<>(); int iSize = list.size()/1000; int iCount = list.size()%1000; for(int i=0;i<=iSize;i++){ List<T> newObjList = new ArrayList<>(); if(i==iSize){ for(int j =i*1000;j<i*1000+iCount;j++ ){ newObjList.add(list.get(j)); } }else{ for(int j =i*1000;j<(i+1)*1000;j++ ){ newObjList.add(list.get(j)); } } if(newObjList.size()>0){ objectlist.add(newObjList); } } return objectlist; }
阅读全文
0 0
- 解决mybatis in语句不能大于1000的问题
- myBatis大于1000的in查询解决办法
- sql语句当in后的个数大于1000时出现的问题
- oracle中sql语句中的in的条件数量大于1000有问题
- MyBatis解决In问题
- 解决QNetworkAccessManager实现ftp功能后,不能上传大于1G文件的问题
- 解决Mybatis使用log4j不能打印sql的问题
- mybatis sql语句配置大于号小于号的处理
- mybatis in 语句的备忘
- MyBatis 和 ibatis的动态SQL语句配置符号,不兼容大于号、小于号等特殊符号问题
- mybatis处理xml中SQL语句的大于、小于、大于等于、小于等于
- mybatis中不能写大于小于符号
- SQLServer的一个奇怪问题:数据库文件不能大于4G?
- 转:Oracle中的rownum不能使用大于>的问题
- Oracle中的rownum不能使用大于>的问题
- [转]Oracle中的rownum不能使用大于>的问题
- 转:Oracle中的rownum不能使用大于>的问题
- 转:Oracle中的rownum不能使用大于>的问题
- Attention和增强RNNs—翻译Attention and Augmented Recurrent Neural Networks
- 关于tomcat编译项目为什么不在webapps文件夹下而在wtpwebapps下怎么改
- 控制td里面的内容不换行
- 算法
- P43-3.2
- 解决mybatis in语句不能大于1000的问题
- elk日志分布式集中管理服务搭建
- 序列化
- esayui时间Date转为String类型
- [译文]Android Studio 3.0 发行说明
- 后台语言
- JAVA中StringUtils的使用
- java公网部署调用第三方API连接问题报错
- php分页