mybatis in语句不能大于1000的问题及解决

 更新时间:2023年11月03日 10:29:07   作者:不如递归  
这篇文章主要介绍了mybatis in语句不能大于1000的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

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) and 
		 (
                <foreach collection="ids" item="idsItem" separtor="or">
                	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;
    }

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 30种SQL语句优化的方法汇总

    30种SQL语句优化的方法汇总

    这篇文章从30个方面,分享了sql优化的一些小技巧,希望对你有所帮助,需要的朋友可以参考下
    2022-10-10
  • MySQL 查询树结构方式

    MySQL 查询树结构方式

    今天小编就为大家分享一篇MySQL 查询树结构方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • 如何解决MySQL安装遇到Start service红叉问题

    如何解决MySQL安装遇到Start service红叉问题

    在安装MySQL时,若遇到StartService步骤打红叉无法继续,可通过计算机管理以管理员身份运行服务,找到MySQL服务,更改为本地系统账户登录,解决安装问题,此方法为实际操作经验,可供参考,确保安装顺利完成
    2024-10-10
  • MySQL中参数sql_safe_updates在生产环境的使用详解

    MySQL中参数sql_safe_updates在生产环境的使用详解

    这篇文章主要给大家介绍了关于MySQL中参数sql_safe_updates在生产环境使用的相关资料,并给大家分享了解决mysql sql_safe_updates不支持子查询更新的方法,分享出来供大家参考学习,需要的朋友们下面来一起看看吧。
    2017-11-11
  • Mysql MVCC机制原理详解

    Mysql MVCC机制原理详解

    这篇文章主要介绍了Mysql MVCC机制原理详解,帮助大家更好的理解和学习使用MySQL,感兴趣的朋友可以了解下
    2021-04-04
  • MySQL 亿级数据导入导出及迁移笔记

    MySQL 亿级数据导入导出及迁移笔记

    上周被安排做了一个MySQL亿级数据的迁移,特此记录一下,导入和导出是两个过程,本文想详细的介绍一下具体的使用,感兴趣的小伙伴们可以参考一下
    2021-06-06
  • Linux下如何实现Mysql定时任务

    Linux下如何实现Mysql定时任务

    这篇文章主要介绍了Linux下如何实现Mysql定时任务,需要的朋友可以参考下
    2018-04-04
  • 实现mysql级联复制的方法示例

    实现mysql级联复制的方法示例

    这篇文章主要介绍了实现mysql级联复制的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • 在Qt中操作MySQL数据库的实战指南

    在Qt中操作MySQL数据库的实战指南

    QT连接Mysql数据库的步骤相对繁琐,但是也是一个不错的学习经历,下面这篇文章主要给大家介绍了关于在Qt中操作MySQL数据库的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-04-04
  • 定时备份mysql, 定时切割nginx access log的方法

    定时备份mysql, 定时切割nginx access log的方法

    定时备份mysql, 定时切割nginx access log的方法,需要的朋友可以参考下。
    2011-09-09

最新评论