MyBatis中foreach循环的用法
Posted wgc-blog
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MyBatis中foreach循环的用法相关的知识,希望对你有一定的参考价值。
一、在了解foreach之前,先了解一下mybatis传入参数及parameterType
1、我们在Dao层向对应的mapper.xml文件传递参数时,可以传递的参数有:
①、基本数据类型(如int/Integer、long/Long、float等)
②、简单引用数据类型(如String、User实体类对象等)
③、集合数据类型(如List、Map等)
我们在parameterType属性获取参数类型时,只需要与传入的参数类型相同即可,如:
①基本数据类型:Java代码:
1 User findById(Integer id);
①基本数据类型:mapper.xml代码:
1 <select id="findById" parameterType="int" resultType="com.demo.entity.User"> 2 SELECT * FROM `user` where id=#{id}; 3 </select>
②简单引用类型:Java代码:
1 void addUser(User user);
②简单引用类型:mapper.xml代码:
1 <insert id="addUser" parameterType="com.demo.entity.User"> 2 insert into `user` values (null,#{userName},#{userAge}) 3 </insert>
③集合数据类型(List):Java代码:
1 List<User> findUserListByIdList(List<Integer> idList);
③集合数据类型(List):mapper.xml代码:
1 <select id="findUserListByIdList" parameterType="List" resultType="User"> 2 select * from `user ` 3 <where> 4 user.ID in 5 <foreach collection="idList" index="index" item="value" open="(" close=")" separator=","> #{value} </foreach> 6 </where> 7 </select>
二、foreach属性——collection、index、item、open、close、separator
属性 | 描述 |
collection |
要做foreach的对象,作为入参时,List<?>对象默认用list代替作为键,数组对象有array代替作为键,Map对象没有默认的键。 |
index | 在list和数组中,index是元素的序号,在map中,index是元素的key,该参数可选。 |
item | 循环体中的具体对象。支持属性的点路径访问,如item.age,item.info.details。 具体说明:在list和数组中是其中的对象,在map中是value。 该参数为必选。 |
open | foreach代码的开始符号,一般是(和close=")"合用。常用在in(),values()时。该参数可选。 |
close | foreach代码的关闭符号,一般是)和open="("合用。常用在in(),values()时。该参数可选。 |
separator | 元素之间的分隔符,例如在in()的时候,separator=","会自动在元素中间用“,“隔开,避免手动输入逗号导致sql错误,如in(1,2,)这样。该参数可选。 |
三、foreach简单使用:
(一)集合数据类型:Map<String, Object>
1 // 初始化一个Map数据 2 Map<String, Object> dataMap = new HashMap<String, Object>(); 3 dataMap.put("id", "0001"); 4 dataMap.put("name", "Tom"); 5 dataMap.put("age", "12"); 6 // 将dataMap传递到Dao层 7 public void addUser(@Param("map") Map<String, Object> map); 8 // DaoMapper.xml mapper文件 9 /* 这段添加语句的意思是:根据map提供的字段,向数据库user表中,添加数据(只添加指定字段的数据);注意区分mybatis中“$”与“#”的用法 */ 10 <insert id="addUser" parameterType="Map"> 11 INSERT INTO `user` 12 <foreach collection="map" index="key" item="value" open="(" 13 close=")" separator=","> 14 ${key} 15 </foreach> 16 VALUES 17 <foreach collection="map" index="key" item="value" open="(" 18 close=")" separator=","> 19 #{value} 20 </foreach> 21 </insert>
(二)集合数据类型:List<Map<String, Object>> (list集合中存的是map)
1 // 初始化一个数据 2 Map<String, Object> dataMap1 = new HashMap<String, Object>(); 3 Map<String, Object> dataMap2 = new HashMap<String, Object>(); 4 List<Map<String, Object>> dataList = new ArrayList<Map<String, Object>>(); 5 dataMap1.put("name", "Tom"); 6 dataMap1.put("age", "13"); 7 dataList.add(dataMap1); 8 dataMap2.put("name", "Jack"); 9 dataMap2.put("age", "18"); 10 dataList.add(dataMap2); 11 // 将dataList传递到Dao层 12 public void addUser(List<Map<String, Object>> list); 13 // DaoMapper.xml 14 /* 批量向数据库中添加数据 */ 15 <insert id="addUser" parameterType="List"> 16 INSERT INTO `user`(name, age) VALUES 17 <foreach collection="list" index="index" item="item" separator=","> 18 <foreach collection="item" index="key" item="value" open="(" close=")" separator=","> 19 #{value} 20 </foreach> 21 </foreach> 22 <insert>
(三) 集合数据类型:Map<String,Object>(map集合中存的数据有:String, List(List里面存的是Map);)
1 // 初始化数据 2 // lineColumn 用来存需要添加的字段 3 String lineColumn = ""; 4 // paramsMap 用来打包整个数据,并将数据传递到Dao层 5 Map<String, Object> paramsMap = new HashMap<String, Object>(); 6 // 创建两个map,用来存对应的字段和值,一个map就是一个新用户 7 Map<String, Object> dataMap1 = new HashMap<String, Object>(); 8 Map<String, Object> dataMap2 = new HashMap<String, Object>(); 9 // 创建一个list,以list来存用户的map集合 10 List<Map<String, Object>> linList = new ArrayList<Map<String, Object>>(); 11 dataMap1.put("name", "Tom"); 12 dataMap1.put("age", "12"); 13 linList.add(dataMap1); 14 dataMap2.put("name", "Jack"); 15 dataMap2.put("age", "18"); 16 linList.add(dataMap2); 17 for(String key : dataMap1.keySet()){ 18 lineColumn += key + ","; 19 } 20 lineColumn = lineColumn.substring(0,lineColumn.lingth() - 1); 21 paramsMap.put("lineColumn", lineColumn); 22 paramsMap.put("table", "user"); 23 paramsMap.put("lineList", lineList); 24 // 将paramsMap传递到Dao层 25 public void addUser(Map<String, Object> map); 26 // DaoMapper.xml; 根据map中传递的 表名, 字段名, 字段对应的数据 进行批量添加 27 /* 在Dao层传入的map集合做数据中,如果只需要拿map集合中某一个指定的单条数据时,在mapper.xml中可以 以 ${key} 即可拿到数据 */ 28 <insert id="addUser" parameterType="Map"> 29 INSERT INTO `${table}` (${lineColumn}) VALUES 30 <foreach collection="lineList" index="index" item="item" separator=","> 31 <foreach collection="item" index="key" item="value" open="(" close=")" separator=","> 32 #{value} 33 </foreach> 34 </foreach> 35 </insert>
(四)数据集合类型:Map(根据集合中value是否为null来选择性的向数据库添加数据)
1 // 初始化一个数据 2 Map<String, Object> dataMap = new HashMap<String, Object>(); 3 dataMap.put("id", "001"); 4 dataMap.put("name","Tom"); 5 dataMap.put("age", null); 6 // 传递到Dao层 7 public void addUser(@Param("map") Map<String, Object> map); 8 // DaoMapper.xml 9 /* 根据参数是否为null来选择性的向数据库添加数据 */ 10 <insert id="addUser" parameterType="Map"> 11 INSERT INTO `user` 12 <foreach collection="map" index="key" item="value" open="(" close=")" separator=","> 13 <if test="value != null and value != ‘‘ "> 14 ${key} 15 </if> 16 </foreach> 17 VALUES 18 <foreach collection="map" index="key" item="value" open="(" close=")" separator=","> 19 <if test="value != null and value != ‘‘ "> 20 #{value} 21 </if> 22 </foreach> 23 </insert>
*在mapper.xml中,使用"if"或者"where"标签小小的注意事项:
在使用if或者where标签时,如<if test=" id != null ">(当你传递参数是一个单类型时( user findById(Integer id); )),有可能报一个异常“There is no getter for property named ‘xxx’ in ‘class java.lang.xxx‘;
此时解决办法:
①将<if test=" id != null "> 中的“id”更改为“_parameter”;
②在接口方法中(user findById (Integer id);)添加@Param("xxx")注解,如user findById (@Param("id") Integer id)
以上是关于MyBatis中foreach循环的用法的主要内容,如果未能解决你的问题,请参考以下文章