mybatis批量插入插入数据、批量条件查询

ps:参考文章连接:https://www.cnblogs.com/admol/articles/4248159.html

关于个人的使用经验:先把数据放到bean中,多个的话就全放入list集合,如下代码:
/* * 把图片信息写入taichi本地数据库 * 参数样例: * { "paramList": [{ "serviceOrderName": "服务单号", "serviceOrderId": "服务单id", "supplierId": "供应商id", "classifyId": 5, "imageUrlList": [ "url1", "url2", "url3" ] }, { "serviceOrderName": "服务单号2", "serviceOrderId": "服务单id2", "supplierId": "供应商id2", "classifyId": 5, "imageUrlList": [ "2url1", "2url2", "2url3" ] } ] } */ @RequestMapping(value = "/image/writeImageInfo", method = RequestMethod.POST) public ResponseWrapper writeImageInfo( @RequestBody WriteImageDTO WriteImageDTO){ ResponseWrapper returnResult = new ResponseWrapper(); List paramList = WriteImageDTO.getParamList(); if(paramList == null || paramList.size() < 1){ log.info("图片信息入库参数为空"); returnResult.setSuccess(false); returnResult.setMsg("图片信息入库参数为空"); return returnResult; } try{ List tempParamList = new LinkedList(); for (ImageInfoForWriteDataBase imageInfoForWriteDataBase : paramList) { List imageUrlList = imageInfoForWriteDataBase.getImageUrlList(); for (String stringObj : imageUrlList) { ImageInfoDTO obj = new ImageInfoDTO(); obj.setServiceOrderName(imageInfoForWriteDataBase.getServiceOrderName()); obj.setServiceOrderId(imageInfoForWriteDataBase.getServiceOrderId()); obj.setSupplierId(imageInfoForWriteDataBase.getSupplierId()); obj.setClassifyId(imageInfoForWriteDataBase.getClassifyId()); obj.setClassifyName(ImageClassifyEnum.getNameStatic(imageInfoForWriteDataBase.getClassifyId())); obj.setImageUrl(stringObj); tempParamList.add(obj); } } Integer result = partsService.writeImageInfo(tempParamList);//数据入库 if(result > 0){ returnResult.setSuccess(true); return returnResult; }else{ returnResult.setSuccess(false); returnResult.setMsg("图片信息入库失败"); return returnResult; } }catch(Exception e){ log.info("图片信息入库异常,==>e.getMessage:"+e.getMessage()+",==>e.getStackTrace():"+e.getStackTrace()+",==>e:"+e); returnResult.setSuccess(false); returnResult.setMsg("图片信息入库异常"); } return returnResult; } public Integer writeImageInfo(List tempParamList){ return operateTaichiDao.writeImageInfo(tempParamList); } Integer writeImageInfo(List tempParamList); insert into imageinfo (serviceOrderName, serviceOrderId, supplierId, classifyId,classifyName,imageUrl) values ( #{node.serviceOrderName}, #{node.serviceOrderId}, #{node.supplierId}, #{node.classifyId}, #{node.classifyName}, #{node.imageUrl} ) 注意:上面sql中collection = 一定要写成list,刚开始我写的是参数的名字tempParamList,会报错说站不到参数集合tempParamList,刚开始我还以为是上面文章中的作者写错了。尴尬。 另外,关于传入list数据作为查询条件的sql代码也一并放在这: dao层代码: List getServiceOrderAlreadyList(@Param("statusNumberList") List statusNumberList, @Param("newSrvWorkerId") String newSrvWorkerId); mapper.xml中的对应的部分sql: and new_srv_workorder.new_dealstatus in #{statusNum} 这里可以看到:collection属性是和参数名字是一样的。

 =================================2019年4月12  补充

今天又遇到这个问题了,就是xml中的sql 的collection到底是list还是和mapper中的变量名保持一致呢?今天发现是自己使用错了注解。

dao接口的mapper中

List selectDeatailInfoByIdList(@Param("paramIdList") List paramIdList);

引入@Param的注解,错引入成 import org.springframework.data.repository.query.Param;

然后xml的sql中collection = paramIdList  ,程序运行sql报错。把collection 改为  collection = list,即可。

或者

引入@Param的注解,使用   import org.apache.ibatis.annotations.Param;(其实应该用这个注解),

然后xml的sql中collection = paramIdList  ,程序不会报错。

所以,如果有多个list的参数情况下,看collection肯定要自定义,不能全写为list的。所以,使用注解 import org.apache.ibatis.annotations.Param;  才是正解!!!

 

============20190419  今天发现一篇博客,讲的是同一个问题:连接: https://blog.csdn.net/qq_28379809/article/details/83342196

转载于:https://www.cnblogs.com/dxxdsw/p/10653660.html

你可能感兴趣的:(mybatis批量插入插入数据、批量条件查询)