MyBatis 实现批量插入和删除中双层循环的写法案例
本博客主要用两个例子来说明一下批量删除和批量插入双层循环的用法,顺便自己记录一下,方便以后使用。
1、批量删除
(1):dao中的写法:
public int batchDelPrice(@Param("deleteList")List<Map<String, Object>> deleteList);
其中deleteList是一个Map的集合,Map中的Object是一个list集合,deleteList拼接如下:
List<String> deletePriceId = getDelPriceId(oriPriceId,nowPriceId); Map<String,Object> deleteMap = new HashMap<String,Object>(); deleteMap.put("userCode", userCode); deleteMap.put("delete", deletePriceId); deleteList.add(deleteMap);
(2):xml中的写法:
<delete id="batchDelPrice" parameterType="java.util.ArrayList"> <foreach collection="deleteList" item="deleteItem" separator=";"> delete from xxx where user_code = #{deleteItem.userCode} and product_id in <foreach collection="deleteItem.delete" item="item" index="index" open="(" close=")" separator=","> #{item} </foreach> </foreach> </delete>
注意:批量删除操作,每个sql间是以分号间隔的,即最外层分隔符是separator=";"。
2、批量插入:
(1):dao中的写法:
public int batchAddPrice(@Param("addList")List<Map<String, Object>> newAddList);
newAddList中的数据拼接如下:
List<Map<String,Object>> newAddList = new ArrayList<Map<String,Object>>(); for(int i = 0; i < addList.size(); i++){ Map<String,Object> userMap = addList.get(i); //获取需要增加的产品id集合 List<String> priceIds = (List<String>) userMap.get("add"); List<Map<String,Object>> priceList = new ArrayList<Map<String,Object>>(); //遍历产品id集合,取相应的产品默认价格,组装成一个新的产品+默认价格集合 for(int j = 0; j < priceIds.size(); j++){ Map<String,Object> priceMap = new HashMap<String,Object>(); String priceId = priceIds.get(j); //取相应产品id的默认价格 double defPrice = productDefPrice.get(Integer.valueOf(priceId)).get("default_price"); priceMap.put("priceId", priceId); priceMap.put("defPrice", defPrice); priceList.add(priceMap); } userMap.put("priceList", priceList); newAddList.add(userMap); }
(2):xml中的写法:
<insert id="batchAddPrice" parameterType="java.util.ArrayList"> insert into xxx( user_code,product_id,price,efftime,index_num,pubtime )values <foreach collection="addList" item="addItem" separator="," > <foreach collection="addItem.priceList" item="priceItem" index="priceIndex" separator=","> ( #{addItem.userCode},#{priceItem.priceId},#{priceItem.defPrice},now(),1,now() ) </foreach> </foreach> </insert>
以上是批量插入和批量删除的其中一种写法,有用到双层循环的可以借鉴一下,有什么意见希望大家提出来。
此外。在使用过程中如果想让查询出的多条记录变成一个Map,想直接通过map.get(key)方式获取value的同学,可以参考下面的一个写法:
(1):dao中的写法:
@MapKey("product_id") public Map<Integer,Map<Integer,Double>> queryProductDefPrice();
其中@MapKey中是你要当成查出的map的key值的字段名称,Map<Integer,Double>中的字段为查询出的字段,我这里查出的Map是:{1={product_id=1,default_price=10.0}}
(2):xml中的写法:
<select id="queryProductDefPrice" resultType="java.util.HashMap"> select product_id,default_price from xxx </select>
希望对大家有所帮助。
补充:mybatis 两层循环的insert语句
使用这个insert语句可以在表名,字段名称和字段个数都不确定的情况下插入数据。
<insert id="insertOneSheet" parameterType="map"> <foreach collection = "lineList" item ="item" index ="index"> insert into ${table}(${lineColumn}) values (<foreach collection="item" index ="key" item="_value" separator=","> #{_value} </foreach>) </foreach> </insert>
这个insert接收一个map)作为参数,其中放了,一个List,两个字符串。其中字符串分别是table(要插入的表名),lineColumn(列名)这在insert语句中都有用到。
第一层循环遍历List,其中存放的是一条条要插入数据库的数据,其中每条数据保存在一个map中。
第二层循环每次遍历一个从List中取出的map。
区分两个map,一个是作为参数的map,paramMap,里面有表名,字段名,LIst,一个是存放一行数据的map,dataMap
lineConlumn 是通过字符串拼接得到的。形如: 字段1,字段2,字段3
以上为个人经验,希望能给大家一个参考,也希望大家多多支持猪先飞。如有错误或未考虑完全的地方,望不吝赐教。
相关文章
- 这篇文章主要介绍了Mybatis Plus select 实现只查询部分字段的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-01
- 这篇文章主要介绍了解决Mybatis 大数据量的批量insert问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-01-09
- 这篇文章主要介绍了mybatis的Configuration详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-11-04
mybatis 返回Integer,Double,String等类型的数据操作
这篇文章主要介绍了mybatis 返回Integer,Double,String等类型的数据操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-25- 这篇文章主要介绍了mybatis-plus 处理大数据插入太慢的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-12-18
- 这篇文章主要介绍了Java8处理List的双层循环问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-08-19
jquery中常用的SET和GET$(”#msg”).html循环介绍
复制代码 代码如下: $(”#msg”).html(); //返回id为msg的元素节点的html内容。 $(”#msg”).html(”new content“); //将“new content” 作为html串写入id为msg的元素节点内容中,页面显示粗体的new content $(”...2013-10-13浅谈Java8 的foreach跳出循环break/return
这篇文章主要介绍了Java8 的foreach跳出循环break/return,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-07-28- 在debian环境下,彻底解决mysql无法插入和显示中文的问题Linux下Mysql插入中文显示乱码解决方案mysql -uroot -p 回车输入密码进入mysql查看状态如下:默认的是客户端和服务器都用了latin1,所以会乱码。解决方案:mysql>use...2013-10-04
- 当unique列在一个UNIQUE键上插入包含重复值的记录时,我们可以控制MySQL如何处理这种情况:使用IGNORE关键字或者ON DUPLICATE KEY UPDATE子句跳过INSERT、中断操作或者更新旧记录为新值。mysql> create table menus(id t...2015-11-08
- 数据库中的数据删除会分为两种:物理删除 和 逻辑删除,接下来通过本文给大家介绍MyBatis-Plus的物理删除和逻辑删除使用场景分析,感兴趣的朋友一起看看吧...2021-09-25
Springboot如何使用mybatis实现拦截SQL分页
这篇文章主要介绍了Springboot使用mybatis实现拦截SQL分页,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-06-19- 这篇文章主要介绍了Mybatis执行update失败的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-01
- 这篇文章主要介绍了Mybatis plus中使用in查询出错的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-08-06
- 这篇文章主要介绍了C#中的基本循环:while循环、for循环和foreach循环,大家都知道循环结构可以简化程序编码,更好地实现理想的效果,并结合案例给大家讲解,需要的朋友可以参考下...2020-06-25
解决Mybatis中mapper.xml文件update,delete及insert返回值问题
这篇文章主要介绍了解决Mybatis中mapper.xml文件update,delete及insert返回值问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-23- Mybatis-Plus是一个Mybatis的增强工具,它在Mybatis的基础上做了增强,却不做改变,Mybatis-Plus是为简化开发、提高开发效率而生,但它也提供了一些很有意思的插件,比如SQL性能监控、乐观锁、执行分析等,下面一起看看mybatis-plus雪花算法自动生成机器id原理解析...2021-06-04
- 这篇文章主要介绍了Mybatis用注解写in查询的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-07-13
- 这篇文章主要介绍了shell中的for循环用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-07-11
mybatis-plus mapper中foreach循环操作代码详解(新增或修改)
这篇文章主要介绍了mybatis-plus mapper中foreach循环操作代码详解(新增或修改),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-11-17