传入的请求具有过多的参数。该服务器支持最多 2100 个参数。请减少参数的数目,然后重新发送该请求。<EOL>; uncategorized SQLException; SQL state [S000
创始人
2025-01-19 18:03:08
0

在做批量插入的时候

难免会遇到例如list的数目过多,导致一次性批量插入的参数超过限定数量

此时就会报错:microsoft.sqlserver.jdbc.SQLServerException: 传入的请求具有过多的参数。该服务器支持最多 2100 个参数。请减少参数的数目,然后重新发送该请求。; uncategorized SQLException; SQL state [S0001]; error code [8003]; 传入的请求具有过多的参数。该服务器支持最多 2100 个参数。请减少参数的数目,然后重新发送该请求。; nested exception is com.microsoft.sqlserver.jdbc.SQLServerException: 传入的请求具有过多的参数。该服务器支持最多 2100 个参数。请减少参数的数目,然后重新发送该请求。

此时最简单的思路就是把list分段进行批量插入:

现在提供一个现成的代码,直接copy可用:

    //获取list     List list = eaMapper.getProductionOrder();          int batchSize = 1000; // 每批次插入的数据量      if (list != null && list.size() > 0) {         for (int i = 0; i < list.size(); i += batchSize) {             int toIndex = Math.min(i + batchSize, list.size());             List subList = list.subList(i, toIndex);             mxProductionOrdMapper.batchInsert(subList);         }     } 

引入了一个 batchSize 变量来表示每批次插入的数据量。然后使用循环和 subList 方法将原始列表拆分成多个小列表,每个小列表包含最多 batchSize 条数据,然后逐个插入到数据库中。

这样做可以确保每次插入的参数数量不会超出数据库的限制,从而解决报错问题。

注意的是不要超过参数的阈值.

阈值除以你数据库插入一个的参数值的和值就是你能插入的最大数量的list集合数量.

相关内容

热门资讯

日前!游戏老友地方有脚本吗,原... 日前!游戏老友地方有脚本吗,原来有挂辅助神器(有挂助手)-哔哩哔哩1、在游戏老友地方有脚本吗插件功能...
做出回应!拱趴游戏破解器,新5... 做出回应!拱趴游戏破解器,新518互游辅助器,指引辅助教程(有挂方式)-哔哩哔哩1、拱趴游戏破解器脚...
为了进一步!小程序能不能开挂,... 为了进一步!小程序能不能开挂,总是真的有辅助修改器(有挂技巧)-哔哩哔哩小薇(辅助器软件下载)致您一...
透视肯定!pokermaste... 透视肯定!pokermaster破解版,潮友会辅助器,妙计辅助app(有挂分析)-哔哩哔哩1、不需要...
近日!蜀山四川破解好友版辅助,... 近日!蜀山四川破解好友版辅助,一直是真的辅助挂(有挂教程)-哔哩哔哩1、蜀山四川破解好友版辅助公共底...
经核实!菠萝德普辅助器免费版在... 经核实!菠萝德普辅助器免费版在哪里,杭州都莱到底有没有挂,步骤辅助软件(真的有挂)-哔哩哔哩1.菠萝...
此事引发网友热议!上品游戏辅助... 此事引发网友热议!上品游戏辅助器,本来真的有辅助下载(有人有挂)-哔哩哔哩1、上品游戏辅助器辅助器安...
有了最新消息!hardrock... 有了最新消息!hardrock透视工具,广东雀神祈福真的有用吗,大纲辅助app(有挂透视)-哔哩哔哩...
今天上午!心悦海南苹果版辅助,... 今天上午!心悦海南苹果版辅助,真是存在有辅助插件(有挂技术)-哔哩哔哩暗藏猫腻,小编详细说明心悦海南...
透视了解!红龙poker辅助工... 透视了解!红龙poker辅助工具,阿当比鸡有什么技巧吗,教材辅助教程(发现有挂)-哔哩哔哩1、上手简...