亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

MyBatis MapperProvider MessageFormat拼接批量SQL語句執行報錯的原因分析及解決辦法

2024-08-31 01:03:38
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了MyBatis MapperProvider MessageFormat拼接批量SQL語句執行報錯的原因分析及解決辦法的相關資料,需要的朋友可以參考下
 

最近在項目中有這么一段代碼:下載服務器基礎業務數據進行本地批量插入操作,因項目中使用mybatis進行持久化操作,故直接考慮使用mybatis的批量插入功能。

1.以下是Mapper接口的部分代碼

public interface PrintMapper{@InsertProvider(type = PrintMapperProvider.class,method = "insertAllLotWithVehicleCode4H2") void insertAllLotWithVehicleCode(List<LotWithVehicleCodeBO> lotWithVehicleCodes);}

2.對應MapperProvider中函數片段

public String insertAllLotWithVehicleCode4H2(Map<String,List<LotWithVehicleCodeBO>> map){List<LotWithVehicleCodeBO> lotWithVehicleCodeBOs = map.get("list");StringBuilder sb = new StringBuilder("INSERT INTO MTC_LOT_WITH_VEHICLE_CODE (LOT_CODE,PRODUCT_VEHICLE_CODE) VALUES ");MessageFormat messageFormat = new MessageFormat("(" +"#'{'list[{0}].lotCode }," +"#'{'list[{0}].productVehicleCode }" +")"); int size = lotWithVehicleCodeBOs.size(); for (int i = 0; i < size; i++){sb.append(messageFormat.format(new Object[]{i})); if (i < size - 1) sb.append(",");} return sb.toString();}

3.service層

@Transactionalpublic void synchLotWithVehicleCodeToLocalDB(List<LotWithVehicleCodeBO> lotWithVehicleCodeBOs){ if(null != lotWithVehicleCodeBOs && lotWithVehicleCodeBOs.size()>0){printMapper.insertAllLotWithVehicleCode(lotWithVehicleCodeBOs);}}

程序上線的時候沒有發生問題,在業務量猛增的時候,大約同時執行500條以上的時候程序就開始報錯:

Caused by: org.apache.ibatis.builder.BuilderException: Improper inline parameter map format. Should be: #{propName,attr1=val1,attr2=val2}at org.apache.ibatis.builder.SqlSourceBuilder$ParameterMappingTokenHandler.buildParameterMapping(SqlSourceBuilder.java:89)at org.apache.ibatis.builder.SqlSourceBuilder$ParameterMappingTokenHandler.handleToken(SqlSourceBuilder.java:43)at org.apache.ibatis.parsing.GenericTokenParser.parse(GenericTokenParser.java:25)at org.apache.ibatis.builder.SqlSourceBuilder.parse(SqlSourceBuilder.java:24)at org.apache.ibatis.builder.annotation.ProviderSqlSource.createSqlSource(ProviderSqlSource.java:57)... 61 more

異常已指明SQL語句構建問題,DEBUG進去:

問題根源:

MessageFormat messageFormat = new MessageFormat("(" +"#'{'list[{0}].lotCode }," +"#'{'list[{0}].productVehicleCode }," +")");int size = lotWithVehicleCodeBOs.size();for (int i = 0; i < size; i++){   sb.append(messageFormat.format(new Object[]{i}));   if (i<size-1) sb.append(",");}

當size達到3位數以上時構建出的message為:

(#{list[1,000].lotCode },#{list[1,000].productVehicleCode })

解決辦法:messageFormat.format(new Object[]{i+""}



注:相關教程知識閱讀請移步到MSSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久乐国产精品| 深夜福利亚洲导航| 国产精品视频最多的网站| 日韩国产精品视频| 久久久精品国产一区二区| 日本午夜精品理论片a级appf发布| 欧美有码在线观看| www国产91| 精品福利免费观看| 人九九综合九九宗合| 亚洲欧美一区二区三区在线| 久久99精品久久久久久青青91| 久久精品精品电影网| 国产欧洲精品视频| 粉嫩av一区二区三区免费野| 欧美不卡视频一区发布| 日韩av电影免费观看高清| 国内精品美女av在线播放| 欧美视频在线免费看| 热久久免费视频精品| 91精品国产自产91精品| 欧美一级大片视频| 黄色精品在线看| 国产精品久久久久久久久久ktv| 蜜臀久久99精品久久久无需会员| 日韩av色在线| 亚洲精品中文字幕有码专区| 国产成人福利视频| 欧美性猛交99久久久久99按摩| 91社影院在线观看| 国产视频久久久| 亚洲精品98久久久久久中文字幕| 色中色综合影院手机版在线观看| 久久久久久久av| 少妇av一区二区三区| 亚洲石原莉奈一区二区在线观看| 久久久精品网站| 国产aⅴ夜夜欢一区二区三区| 国产精品扒开腿做| 6080yy精品一区二区三区| 色婷婷亚洲mv天堂mv在影片| 日韩精品在线电影| 亚洲第一精品久久忘忧草社区| 亚洲色图在线观看| 国产+人+亚洲| 色综合久久悠悠| 中文字幕精品国产| 亚洲另类欧美自拍| 亚洲一区制服诱惑| 4k岛国日韩精品**专区| 69av成年福利视频| 欧美激情啊啊啊| 久久久中精品2020中文| 国产丝袜一区二区三区免费视频| 欧美精品性视频| 亚洲一区亚洲二区亚洲三区| 亚洲第一色中文字幕| 亚洲天堂av在线播放| 日韩视频永久免费观看| 91久久国产婷婷一区二区| www.亚洲一二| 欧美午夜精品久久久久久人妖| 国产久一一精品| 中文字幕日韩精品在线观看| 91在线看www| 欧美激情视频在线观看| 精品毛片三在线观看| 国产一区红桃视频| 欧美大片在线看| 亚洲一区二区免费在线| 欧洲亚洲免费视频| 国产成人97精品免费看片| 国产精品一区二区女厕厕| 少妇高潮 亚洲精品| 亚洲成人网av| 黄网动漫久久久| 91精品国产综合久久久久久蜜臀| 国产精品日韩欧美大师| 亚洲成人av片在线观看| 国产成人精品免费视频| 最新的欧美黄色| 日韩电影免费观看在线观看| 精品国产视频在线| 91综合免费在线| 精品亚洲一区二区三区| 久久精品色欧美aⅴ一区二区| 51精品在线观看| 日韩hd视频在线观看| 欧美激情视频一区二区| 色偷偷偷综合中文字幕;dd| 97视频在线观看免费高清完整版在线观看| 日韩中文字幕在线视频| 亚洲最大成人网色| 亚洲a级在线观看| 色婷婷综合久久久久中文字幕1| 国产精品电影久久久久电影网| 精品亚洲国产视频| 国产精品69精品一区二区三区| 最新69国产成人精品视频免费| 亚洲精品成a人在线观看| 九九热精品视频| 大量国产精品视频| 欧美一区二区三区艳史| 国内免费精品永久在线视频| 日韩中文综合网| 日韩欧美在线观看| 日韩电影大片中文字幕| 欧美精品videossex88| 亚洲a成v人在线观看| 国产精品福利片| 欧美视频一二三| 亚洲成av人片在线观看香蕉| 91影视免费在线观看| 国产精品美女av| 26uuu国产精品视频| 色天天综合狠狠色| 国产一区二区免费| 久久久久久久成人| 亚洲激情 国产| 国产一区二区三区丝袜| 国产z一区二区三区| 亚洲人成网站999久久久综合| 国产精品欧美在线| 亚洲第一黄色网| 亚洲色图35p| 国产日韩欧美自拍| 97欧美精品一区二区三区| 北条麻妃一区二区三区中文字幕| 久久久噜久噜久久综合| 国产成人亚洲综合91| 欧美高清性猛交| 国产成人精品免高潮在线观看| 欧美成人一区二区三区电影| 91中文在线视频| 国产成人激情小视频| 在线国产精品视频| 久久久久国产精品www| 91在线免费视频| 欧美黑人一区二区三区| 51色欧美片视频在线观看| 91在线视频导航| 亚洲人成网7777777国产| 91免费高清视频| 久久久亚洲网站| 欧美精品18videos性欧| 国产精品久久久久久久久久东京| 日韩精品在线第一页| 亚洲综合成人婷婷小说| 久久精品精品电影网| 2019中文字幕在线观看| 全球成人中文在线| 欧美黑人一级爽快片淫片高清| 国产精品美女无圣光视频| 亚洲精品中文字| 欧美中文字幕第一页| 亚洲视频视频在线| 欧美激情一二三| 91中文精品字幕在线视频| 久热精品视频在线观看| 国产精品极品美女在线观看免费| 在线播放国产一区二区三区| 国产视频亚洲精品| 久久精品视频一| 欧美日韩精品二区|