这篇文章主要为大家展示了“Mybatis如何使用动态SQL-foreach遍历集合、批量插入”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Mybatis如何使用动态SQL-foreach遍历集合、批量插入”这篇文章吧。
批量插入数据到数据库在开发时用到的频率非常高,为了节省时间,提高效率,我们不可能逐条插入数据;因此mybatis为开发人员提供了foreach标签。
foreach标签解释:collection="":指明要遍历的集合;
item="":将当前遍历出的元素赋值给指定变量;
separator="":每个元素之间的分隔符;
open="(":遍历出的所有结果以左括号为开始字符;
close=")";遍历出的所有结果以右括号为结束字符;
index="";遍历List的时候索引,item是值;遍历map的时候是key,item是值;
1、【foreach遍历集合】
代码-mapper类:
//测试foreach:遍历 public List<Employee> getEmpByConditionForeach(List emp);
Mapper映射文件:
<!-- //测试foreach:遍历 public List<Employee> getEmpByConditionForeach(Employee employee); --> <select id="getEmpByConditionForeach" resultType="mybatis.learn.bean.Employee"> select * from xjinfo where XH in <foreach collection="list" item="item" separator="," open="(" close=")"> #{item} </foreach> </select>
测试代码:
@Test public void testSelectForeach() throws IOException{ SqlSessionFactory sqlSessionFactory = getSqlSessionFactory(); SqlSession openSession = sqlSessionFactory.openSession(); try { EmployeemapperDynamicSQL mapper = openSession.getMapper(EmployeemapperDynamicSQL.class); List<Employee> emps = mapper.getEmpByConditionForeach(Arrays.asList("2017000001","2017000002","2017000003")); for (Employee emp : emps) { System.out.println(emp); } } finally { openSession.close(); } }
查看控制台打印:
2、【foreach批量插入】
代码-mapper类:
//测试foreach:批量插入 public void addEmpByBatchForeach(@Param("emps")List<Employee> emps);
Mapper映射文件:
<!-- //测试foreach:批量插入 public List<Employee> addEmpByBatchForeach(@Param("emps")List<Employee> emps); --> <insert id="addEmpByBatchForeach"> insert into xjinfo (XH,XM,YJSLB) values <foreach collection="emps" separator="," item="emp"> (#{emp.xh},#{emp.xm},#{emp.yjslb}) </foreach> </insert>
[解释]:Mapper类中的注解@Param("emps")是在foreach中的collection中可以直接使用emps;
测试代码:
@Test public void testBatchInsert() throws IOException{ SqlSessionFactory sqlSessionFactory = getSqlSessionFactory(); SqlSession openSession = sqlSessionFactory.openSession(); try { EmployeemapperDynamicSQL mapper = openSession.getMapper(EmployeemapperDynamicSQL.class); List<Employee> emps = new ArrayList<>(); emps.add(new Employee("2017000000","李一","硕")); emps.add(new Employee("2017000001","李二","博")); mapper.addEmpByBatchForeach(emps); //执行insert update时千万不能忘了提交 openSession.commit(); } finally { openSession.close(); } }
查看控制台打印:
最后整理一下思路:从test测试类开始,传入一个list emps到mapper类的emps中,并在映射文件中emps接收,每一次遍历emps后赋给item的值emp,然后在foreach中用#(emp.xh)接收参数。
以上是“Mybatis如何使用动态SQL-foreach遍历集合、批量插入”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/u/4504531/blog/4981593