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<Object> writeImageInfo( @RequestBody WriteImageDTO WriteImageDTO){ ResponseWrapper<Object> returnResult = new ResponseWrapper<Object>(); List<ImageInfoForWriteDataBase> paramList = WriteImageDTO.getParamList(); if(paramList == null || paramList.size() < 1){ log.info("图片信息入库参数为空"); returnResult.setSuccess(false); returnResult.setMsg("图片信息入库参数为空"); return returnResult; } try{ List<ImageInfoDTO> tempParamList = new LinkedList<ImageInfoDTO>(); for (ImageInfoForWriteDataBase imageInfoForWriteDataBase : paramList) { List<String> 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<ImageInfoDTO> tempParamList){ return operateTaichiDao.writeImageInfo(tempParamList); } Integer writeImageInfo(List<ImageInfoDTO> tempParamList); <insert id ="writeImageInfo" parameterType="java.util.List"> insert into imageinfo (serviceOrderName, serviceOrderId, supplierId, classifyId,classifyName,imageUrl) values <foreach collection ="list" item="node" index= "index" separator =","> ( #{node.serviceOrderName}, #{node.serviceOrderId}, #{node.supplierId}, #{node.classifyId}, #{node.classifyName}, #{node.imageUrl} ) </foreach> </insert > 注意:上面sql中collection = 一定要写成list,刚开始我写的是参数的名字tempParamList,会报错说站不到参数集合tempParamList,刚开始我还以为是上面文章中的作者写错了。尴尬。 另外,关于传入list数据作为查询条件的sql代码也一并放在这: dao层代码: List<OperateTaskCard> getServiceOrderAlreadyList(@Param("statusNumberList") List<String> statusNumberList, @Param("newSrvWorkerId") String newSrvWorkerId); mapper.xml中的对应的部分sql: and new_srv_workorder.new_dealstatus in <foreach collection="statusNumberList" index="index" item="statusNum" open="(" separator="," close=")"> #{statusNum} </foreach> 这里可以看到:collection属性是和参数名字是一样的。
=================================2019年4月12 补充
今天又遇到这个问题了,就是xml中的sql 的collection到底是list还是和mapper中的变量名保持一致呢?今天发现是自己使用错了注解。
dao接口的mapper中
List<EntManagementinfo> selectDeatailInfoByIdList(@Param("paramIdList") List<Integer> 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
mybatis批量插入插入数据、批量条件查询的更多相关文章
- oracle 在xml中批量插入,批量修改及多组条件查询
最近公司用ibatis开发项目,本来可以用存储过程处理批量插入,批量修改及多组条件查询:但由于使用模块相对较小,暂时就在xml中配置,以前没有在xml做过类似处理,有必要记录一下:好了,代码如下: & ...
- sql大数据多条件查询索引优化
此优化的前提可以称之为最近流行的头条人物“许三多”,总数据多,查询条件多,返回列多 优化前分页查询内部select列为需要的全部列,优化后内部select只返回ID主键,外部查询关联原数据表,然后查出 ...
- JQueryEasyUI-DataGrid显示数据,条件查询,排序及分页
<html><head> <title></title> <script src="/jquery-easyui-1.3.4 ...
- Mybatis plus中一个框多条件查询 SQL拼接
遇到多条件查询时,只用框架自带的方法搞不定,只能自己写方法拼接 EntityWrapper<YcejShopEntity> wrapper = new EntityWrapper<& ...
- mysql数据库表插入单条数据/批量插入数据
1.创建表格 reate table trade( id int(4) not null primary key auto_increment, product varchar(30) null, p ...
- MyBatis(十一):Mybatis 动态SQL语句完成多条件查询
之前文章中对in的用法做过讲解:<MyBatis(四):mybatis中使用in查询时的注意事项> 实际上对于多个参数的用法也是这是注意的: 多参&if判空&List集合判 ...
- sql根据一个表查询的数据作为条件查询另一个表
代码格式如下: ) 要注意的是:in后面的查询语句必须是查询一个字段跟前面的表相对应的.比如要根据订单号orderID,OpenBills 这个表就需要查询到orderID这个字段,BillConsu ...
- MySQL数据库6 -查询基础,简单查询,条件查询,对查询结果排序
一.SELECT语句 SELECT COL1,COL2,....COLn FROM TABLE1,TABLE2,....TABLEn [WHERE CONDITIONS] -- 查询条件 [GROUP ...
- MySQL数据库—查询基础,简单查询,条件查询,对查询结果排序
一.SELECT语句 SELECT COL1,COL2,....COLn FROM TABLE1,TABLE2,....TABLEn [WHERE CONDITIONS] -- 查询条件 [GROUP ...
- 多线程查询数据,将结果存入到redis中,最后批量从redis中取数据批量插入数据库中【我】
多线程查询数据,将结果存入到redis中,最后批量从redis中取数据批量插入数据库中 package com.xxx.xx.reve.service; import java.util.ArrayL ...
随机推荐
- SVN使用技巧和参考文档总结
以下文章为网上收集: myEclipse 8.5下SVN环境的搭建(重点推荐) SVN建立版本库,配置用户和权限 Tortoise SVN使用方法,简易图解 版本控制软件SVN使用方法详解 学习笔记 ...
- Umbraco back office 中form显示不出来的问题
问题纠结了好久,没找到什么原因,具体就是在back office中,form显示不出来.如下: 按下F12,在chrome 的developer tools中发现如下错误 找了半天不知道原因,后来看到 ...
- 1.4 DVWA亲测XSS漏洞
首先需要有配置好的DVWA环境,像下图这样 其中: XSS (DOM) : DOM型XSS漏洞 XSS (Reflected) : 反射性XSS漏洞 XSS (Stored) : 存储型XS ...
- python 里 np.array 的shape (2,)与(2,1)的分别是什么意思,区别是什么?
numpy.ndarray.shap是返回一个数组维度的元组. (2,)与(2,1)的区别如下: ndarray.shape:数组的维度.为一个表示数组在每个维度上大小的整数元组.例如二维数组中, ...
- poj2763(lca / RMQ + 线段树)
题目链接: http://poj.org/problem?id=2763 题意: 第一行输入 n, q, s 分别为树的顶点个数, 询问/修改个数, 初始位置. 接下来 n - 1 行形如 x, y, ...
- heap 堆
实现了交换.向上维护,向下维护的原子功能,其它插入.删除.修改的功能应该不在话下. 于是有了代码:(luogu3378模板题) // luogu-judger-enable-o2 #include & ...
- 洛谷P3006 [USACO11JAN]瓶颈Bottleneck(堆模拟)
传送门 感觉这题的思路还是挺不错的.然而为啥全网就一个题解而且只有代码……然后我只好看着代码理解了好久…… 题意就是有一棵树,每一个节点向他父亲节点连边,且有一个容量表示每一秒可以经过的牛的数量,每一 ...
- [Xcode 实际操作]四、常用控件-(2)UIButton图片按钮的使用
目录:[Swift]Xcode实际操作 本文将演示图片按钮的使用 在项目导航区,打开视图控制器的代码文件[ViewController.swift] import UIKit class ViewCo ...
- AOP分析
cglib动态代理 Waiter target = new NaiveWaiter();//一个实现了Waiter接口的类 BeforeAdvice advice = new GreetingBefo ...
- python之垃圾回收机制
一.前言 Python 是一门高级语言,使用起来类似于自然语言,开发的时候自然十分方便快捷,原因是Python在背后为我们默默做了很多事情,其中一件就是垃圾回收,来解决内存管理,内存泄漏的问题. 内存 ...