一、在了解foreach之前,先了解一下mybatis传入参数及parameterType

1、我们在Dao层向对应的mapper.xml文件传递参数时,可以传递的参数有:

  ①、基本数据类型(如int/Integer、long/Long、float等)

  ②、简单引用数据类型(如String、User实体类对象等)

  ③、集合数据类型(如List、Map等)

  我们在parameterType属性获取参数类型时,只需要与传入的参数类型相同即可,如:

①基本数据类型:Java代码:

 User findById(Integer id);

①基本数据类型:mapper.xml代码:

 <select id="findById" parameterType="int" resultType="com.demo.entity.User">
         SELECT * FROM `user` where id=#{id};
 </select>

②简单引用类型:Java代码:

 void addUser(User user);

②简单引用类型:mapper.xml代码:

 <insert id="addUser" parameterType="com.demo.entity.User">
         insert into `user` values (null,#{userName},#{userAge})
 </insert>

③集合数据类型(List):Java代码:

 List<User> findUserListByIdList(List<Integer> idList);

③集合数据类型(List):mapper.xml代码:

 <select id="findUserListByIdList" parameterType="List" resultType="User">
     select * from `user `
     <where>
         user.ID in
         <foreach collection="idList" index="index" item="value" open="(" close=")" separator=","> #{value} </foreach>
     </where>
 </select>  

二、foreach属性——collection、index、item、open、close、separator

属性 描述
collection

要做foreach的对象,作为入参时,List<?>对象默认用list代替作为键,数组对象有array代替作为键,Map对象没有默认的键。
当然在作为入参时可以使用@Param("keyName")来设置键,设置keyName后,list,array将会失效。 除了入参这种情况外,还有一种作为参数对象的某个字段的时候。举个例子:
如果User有属性List ids。入参是User对象,那么这个collection = "ids"
如果User有属性Ids ids;其中Ids是个对象,Ids有个属性List id;入参是User对象,那么collection = "ids.id"
上面只是举例,具体collection等于什么,就看你想对那个元素做循环。
该参数为必选。

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>

 // 初始化一个Map数据
 Map<String, Object> dataMap = new HashMap<String, Object>();
     dataMap.put("id", "0001");
     dataMap.put("name", "Tom");
     dataMap.put("age", "12");
 // 将dataMap传递到Dao层
 public void addUser(@Param("map") Map<String, Object> map);
 // DaoMapper.xml   mapper文件
 /* 这段添加语句的意思是:根据map提供的字段,向数据库user表中,添加数据(只添加指定字段的数据);注意区分mybatis中“$”与“#”的用法 */
 <insert id="addUser" parameterType="Map">
     INSERT INTO `user`
     <foreach collection="map" index="key" item="value" open="("
         close=")" separator=",">
         ${key}
     </foreach>
     VALUES
     <foreach collection="map" index="key" item="value" open="("
         close=")" separator=",">
         #{value}
     </foreach>
 </insert>

(二)集合数据类型:List<Map<String, Object>> (list集合中存的是map)

 // 初始化一个数据
 Map<String, Object> dataMap1 = new HashMap<String, Object>();
 Map<String, Object> dataMap2 = new HashMap<String, Object>();
 List<Map<String, Object>> dataList = new ArrayList<Map<String, Object>>();
     dataMap1.put("name", "Tom");
     dataMap1.put("age", "13");
     dataList.add(dataMap1);
     dataMap2.put("name", "Jack");
     dataMap2.put("age", "18");
     dataList.add(dataMap2);
 // 将dataList传递到Dao层
 public void addUser(List<Map<String, Object>> list);
 // DaoMapper.xml
 /* 批量向数据库中添加数据 */
 <insert id="addUser" parameterType="List">
     INSERT INTO `user`(name, age) VALUES
     <foreach collection="list" index="index" item="item" separator=",">
         <foreach collection="item" index="key" item="value" open="(" close=")" separator=",">
             #{value}
         </foreach>
     </foreach>
 <insert>

(三) 集合数据类型:Map<String,Object>(map集合中存的数据有:String, List(List里面存的是Map);)

 // 初始化数据
 // lineColumn 用来存需要添加的字段
     String lineColumn = "";
 // paramsMap 用来打包整个数据,并将数据传递到Dao层
     Map<String, Object> paramsMap = new HashMap<String, Object>();
 // 创建两个map,用来存对应的字段和值,一个map就是一个新用户
     Map<String, Object> dataMap1 = new HashMap<String, Object>();
     Map<String, Object> dataMap2 = new HashMap<String, Object>();
 // 创建一个list,以list来存用户的map集合
     List<Map<String, Object>> linList = new ArrayList<Map<String, Object>>();
         dataMap1.put("name", "Tom");
         dataMap1.put("age", "12");
         linList.add(dataMap1);
         dataMap2.put("name", "Jack");
         dataMap2.put("age", "18");
         linList.add(dataMap2);
     for(String key : dataMap1.keySet()){
         lineColumn += key + ",";
     }
     lineColumn = lineColumn.substring(0,lineColumn.lingth() - 1);
     paramsMap.put("lineColumn", lineColumn);
     paramsMap.put("table", "user");
     paramsMap.put("lineList", lineList);
 // 将paramsMap传递到Dao层
 public void addUser(Map<String, Object> map);
 // DaoMapper.xml; 根据map中传递的 表名, 字段名, 字段对应的数据 进行批量添加
 /* 在Dao层传入的map集合做数据中,如果只需要拿map集合中某一个指定的单条数据时,在mapper.xml中可以 以 ${key} 即可拿到数据 */
 <insert id="addUser" parameterType="Map">
     INSERT INTO `${table}` (${lineColumn}) VALUES
     <foreach collection="lineList" index="index" item="item" separator=",">
         <foreach collection="item" index="key" item="value" open="(" close=")" separator=",">
             #{value}
         </foreach>
     </foreach>
 </insert>

(四)数据集合类型:Map(根据集合中value是否为null来选择性的向数据库添加数据)

 // 初始化一个数据
 Map<String, Object> dataMap = new HashMap<String, Object>();
     dataMap.put("id", "001");
     dataMap.put("name","Tom");
     dataMap.put("age", null);
 // 传递到Dao层
 public void addUser(@Param("map") Map<String, Object> map);
 // DaoMapper.xml
 /* 根据参数是否为null来选择性的向数据库添加数据 */
 <insert id="addUser" parameterType="Map">
     INSERT INTO `user`
     <foreach collection="map" index="key" item="value" open="(" close=")" separator=",">
         <if test="value != null and value != '' ">
             ${key}
         </if>
     </foreach>
     VALUES
     <foreach collection="map" index="key" item="value" open="(" close=")" separator=",">
         <if test="value != null and value != '' ">
             #{value}
         </if>
     </foreach>
 </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循环的用法的更多相关文章

  1. PHP和Java中foreach循环的用法区别

    1.foreach语句介绍: ①PHP: foreach 语法结构提供了遍历数组的简单方式.foreach 仅能够应用于数组和对象,如果尝试应用于其他数据类型的变量,或者未初始化的变量将发出错误信息. ...

  2. mybatis中foreach的用法(转)

    foreach一共有三种类型,分别为List,[](array),Map三种. foreach属性 属性 描述 item 循环体中的具体对象.支持属性的点路径访问,如item.age,item.inf ...

  3. ecshop中foreach的详细用法归纳

    ec模版中foreach的常见用法. foreach 语法: 假如后台:$smarty->assign('test',$test); {foreach from=$test item=list ...

  4. PHP中foreach循环详解

    首先要说的是,其实我对foreach循环的用法并不是很精通,说详解,其实也只是我自己的理解,希望对你能有点帮助 . 先来看一下foreach的语法: foreach ($array as $key=& ...

  5. Mybatis中使用循环遍历

    Mybatis中传参数的方法 1.使用注解绑定,mapper.xml 对应方法 不需要指定 parameterType,(推荐使用注解绑定方式) 方法接口: List<CalculateIdea ...

  6. SSIS之Foreach循环容器用法

    要实现的业务:A数据库服务器上某库的T_GOODS_DECL的状态字段“Is_Delete”标记为“1”的时候删除B数据库服务器上对应库的T_GOODS_DECL表中的记录,二者的主键为“DECL_N ...

  7. PHP中foreach循环传值问题

    首先看一段代码: <?php $a=array('ab','cd','ef'); $count=3; foreach($a as $key=>$value){ $value='abcdef ...

  8. mybatis中foreach使用

    mybatis中的<foreach collection="list" item="item" index="index" open= ...

  9. c# 中foreach 循环

    使用foreach循环可以迭代数组或一个集合对象, 1.通过foreach 循环输出整型数组中的数组: 2.通过for循环输出整型数组中的元素: 3.foreach 循环设置数组元素的计算器: cla ...

随机推荐

  1. 对result文件进行数据清洗以及进行可视化

    项目源码地址:https://github.com/gayu121/result(项目里操作的数据都是清洗过后的数据) 测试要求: 1. 数据清洗:按照进行数据清洗,并将清洗后的数据导入hive数据库 ...

  2. Spring(六)核心容器 - 注册单例 Bean 实例、SingletonBeanRegistry 简介

    前言 上篇文章我们对注册 Bean 的核心类 BeanDefinitionRegistry 进行了讨论,这里的注册 Bean 是指保存 Bean 的相关信息,也就是将 Bean 定义成 BeanDef ...

  3. copy constructor和copy assignment operator的区别

    拷贝构造函数(copy constructor)被用来以一个对象来初始化同类型的另一个对象,拷贝赋值运算符(copy assignment operator)被用来将一个对象中的值拷贝到同类型的另一个 ...

  4. kendo ui - core

    通过CDN 引入kendo-ui-core git地址:http://www.telerik.com/kendo-ui<link href="http://kendo.cdn.tele ...

  5. Go语言实现:【剑指offer】序列化二叉树

    该题目来源于牛客网<剑指offer>专题. 请实现两个函数,分别用来序列化和反序列化二叉树. 二叉树的序列化是指:把一棵二叉树按照某种遍历方式的结果以某种格式保存为字符串,从而使得内存中建 ...

  6. 用Java反射输出对象的所有属性的值

    获取对象的类类型 Class cls = obj.getClass(); 用类类型获取属性数组 getFields()获取的是共有属性 getDeclaredFields()可以获取所有属性 Fiel ...

  7. sys.stdout.write和print和sys.stdout.flush

    1. 先看下官方文档 """ sys.stdout.write(string) Write string to stream. Returns the number of ...

  8. k8s系列---Service之ExternalName用法

    需求:需要两个不同的namespace之间的不同pod可以通过name的形式访问 实现方式: A:在其他pod内ping [svcname].[namespace] ping出来到结果就是svc的ip ...

  9. elasticsearch kibana 安装 配置

    二.Elasticsearch  配置信息 2.1  因为 Elasticsearch 可以执行脚本文件,为了安全性,默认不允许通过 root 用户启动服务.我们需要新创建用户名和用户组启动服务 2. ...

  10. zabbix-server配置文件详解

    zabbix官方文档:https://www.zabbix.com/documentation/4.0/zh/manual zabbix-server端的配置文件在/etc/zabbix/zabbix ...