mybatis嵌套循环map方式(高级用法)

目录
  • mybatis嵌套循环map
    • mybatis入参map的基本语法
    • mybatis嵌套循环map的高级用法
  • mybatis中循环map集合操作

mybatis嵌套循环map

mybatis有默认的list,array,但是没有默认的map。所以不能直接写collection="map",如果这么写,它会当成是根据map.get(“map”)来取value值,大部分情况下是一个map中是不会有“map”这个key的,于是就是报错。

如果你想用这个“map”标识取参数map,就需要保证传入的Map参数有@Param("map")注解。

mybatis入参map的基本语法

service,dao的写法:

//service:
public List<BpmDefUser> getByMap(Map<String,List<Long>> map){
        Map<String,Object> paramsMap= new HashMap<String, Object>();
        params.put("paramsMap", map);
        return this.getByMap(paramsMap);   
}
//dao:
int getByMap(Map<String,Object> map)

或者(推荐):

//service直接调用dao
int getByMap(@param("paramsMap") Map<String,Object> map)

xml的写法:

循环key:

    <foreach collection="paramsMap.keys" item="k" separator="and">   
        ${k} = #{k}    
    </foreach>   

循环values

<foreach collection="paramsMap.values" item="v" separator="and">   
    ${v} = #{v}    
</foreach>  

循环获取key和值:

<foreach collection="paramsMap.keys" item="k" separator="and">   
    <if test="null != paramsMap[k]">    
        ${k} = ${paramsMap[k]}    
    </if>  
</foreach>   

或者一次循环得到key和value值(推荐):

<foreach collection="paramsMap" index="key"  item="value">
         ${key} = ${value}
</foreach>

易错点:表达式抒写错误

通常我们设置值的时候,会以#{}的方式,而不是${},如下:

<foreach collection="paramsMap.keys" item="k" separator=",">   
    <if test="null != paramsMap[k]">    
        ${k} = #{paramsMap[k]}    
    </if>  
</foreach>   

你会发现,取不了值了,${condition[k]}  能取的出值,但#{condition[k]} 取出来的值却实null,正确的写法应该是:

<foreach collection="paramsMap.keys" item="k" separator=",">   
    <if test="null != paramsMap[k]">    
        ${k} = #{paramsMap[${k}]}  
    </if>  
</foreach>   

mybatis嵌套循环map的高级用法

假如参数类型是这么一个类型结构: Map map = new HashMap<String,HashSet<String>>,我想要拼装出来的sql如下:

select * from 表名
where (
    (id = 1 and name in ('小二','小三','小四') or
    (id = 2 and name in ('小二','小三','赵六') or
    (id = 3 and name in ('小三','王五','王八') or
    ……
)

mybatis应该怎么写?

第一种写法:

 SELECT * FROM 表名
        WHERE 
        <foreach collection="paramsMap.keys" item="key" open="(" separator="OR" close=")">
            (id = #{key} AND name in
              <foreach collection = "paramsMap[key]" item="name" separator="," open="(" close=")">
                  #{name}
              </foreach>
            )
        </foreach>

第二种写法(推荐):

 SELECT * FROM 表名
        WHERE 
        <foreach collection="paramsMap" index="key"  item="value" open="(" separator="OR" close=")">
            (id = #{key} AND name in
              <foreach collection = "value" item="name" separator="," open="(" close=")">
                  #{name}
              </foreach>
            )
        </foreach>

mybatis中循环map集合操作

首先声明一个MAP集合,用来存放数据:如下图:声明map集合pd,将数据put到pd中,然后在声明一个map集合params,将pd几个放入params集合中,将params作为参数,参入xml配置文件中:

在xml中:

传入到xml文件中的集合params里,键值为relationMap对应着另一个map几个pd,所以在<foreach>标签中collection为relationMap,index为map的key,item为map的value;#{key},#{value}即可取到pd这个map集合中的键值。

至于${key},由于我写的是个插入语句,key值作为字段,value作为值,#{key}取出来的为字符串,而oracle数据库表明字段不能为字符串,用${key}取出即可;

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • 详细聊聊Mybatis中万能的Map

    目录 万能的Map demo map 实现add user map 实现通过id查询 多个参数可以使用Map进行传参 总结 万能的Map 假设,我们的实体类,或者数据库中的表,字段或者参数过多,我们需要考虑使用Map 简单来说,map你用什么参数就写什么参数,而实体类需要写所有参数. map不需要名称完全对应,通过键的映射取值,实体类必须要求和实体类中属性名字一样 map传递参数,直接在sql中取出key即可 [parameterType="map"] 对象传递参数,直接在sql中取对

  • mybatis3.4.6 批量更新 foreach 遍历map 的正确姿势详解

    好久没编码了!最近开始编码遇到一个问题 !一个批量修改的问题,就是mybatis foreach 的使用. 当时使用的场景 ,前端 传逗号拼接的字符串id, 修改id对应数据的数据顺序 ,顺序 就是id 的顺序. 就是一个条件(单个id值) 修改一个值(传入的id的顺序) , 1. 把条件作为Map 的key 修改值是value,用map入参 2.用List<Object> 或者数组 ,把条件和值封装成对象放进list集合或者array数组 3.代码使用for循环调用mapper方法 穿两个参

  • mybatis多层嵌套resultMap及返回自定义参数详解

    1.两层嵌套,一个list中加另外一个list data:[ {a:123,b:456,c:[{d:7,e:8}]} ] xml文件定义的sql select * from zhy z LEFT JOIN wl w on z.id = w.zid resultMap可以定义: <resultMap id="zhyResultMap" type="zhy的doman实体" extends="zhy自动生成的BaseResultMap">

  • mybatis动态sql之Map参数的讲解

    mybatis 动态sql之Map参数 Mapper文件: <mapper namespace="com.cn.shoje.oa.modules.logistics.dao.PurcDao"> <select id="findAll" parameterType="Map" resultType="Purchase"> select * from prod_purchase where 1=1 <

  • mybatis嵌套循环map方式(高级用法)

    目录 mybatis嵌套循环map mybatis入参map的基本语法 mybatis嵌套循环map的高级用法 mybatis中循环map集合操作 mybatis嵌套循环map mybatis有默认的list,array,但是没有默认的map.所以不能直接写collection="map",如果这么写,它会当成是根据map.get(“map”)来取value值,大部分情况下是一个map中是不会有“map”这个key的,于是就是报错. 如果你想用这个“map”标识取参数map,就需要保证

  • 浅谈MyBatis循环Map(高级用法)

    今天遇到一个比较特殊的业务,需要对传入的Map数据在映射文件中进行遍历,在之前的学习中,我们也知道MyBatis有默认对集合的操作list和array,但是没有默认的map,所有不能直接写collection="map",如果这么处理,它会当成是根据map.get("map")获取传递value只,==大部分情况下是一个map中是不会有"map"这个key的,于是就是报错==.如果你想用map标识来获取参数map,就需要保证传入的Map参数有@P

  • Mybatis Example的高级用法详解

    目录 Mybatis Example的高级用法 一. mapper接口中的函数及方法 二. example实例方法 三. 使用案例 说说Mybatis Example常见用法 一. 说明 二. 排序查询 三. 查询limit, 只返回前50条数据 Mybatis Example的高级用法 近几个项目一直使用的mybatis来对数据库做查询,期间用到了很多高效简洁的查询方法,特此记录和分享. 一. mapper接口中的函数及方法 方法名 功能 int countByExample(UserExam

  • Java实现Map集合遍历的四种常见方式与用法分析

    本文实例讲述了Java实现Map集合遍历的四种常见方式与用法.分享给大家供大家参考,具体如下: ~Map集合是键值对形式存储值的,所以遍历Map集合无非就是获取键和值,根据实际需求,进行获取键和值 1. 无非就是通过map.keySet()获取到值,然后根据键获取到值 for(String s:map.keySet()){ System.out.println("key : "+s+" value : "+map.get(s)); } 2. 通过Map.Entry(

  • Mybatis返回Map数据方式示例

    目录 一. 方式1 接口 调用 二. 方式2 接口 调用 三. 方式3 接口 调用 一. 方式1 接口 public interface UserMapper { List<Map<String, String>> selectTestData1(); } <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//

  • MyBatis持久层框架的用法知识小结

    MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索.MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录. MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google c

  • 浅谈junit4单元测试高级用法

    Junit单元测试框架是Java程序开发必备的测试利器,现在最常用的就是Junit4了,在Junit4中所有的测试用例都使用了注解的形式,这比Junit3更加灵活与方便.之前在公司的关于单元测试的培训课程中,讲师仅仅讲述了Junit4的基本的与生命周期相关的注解的使用,主要包括@BeforeClass.@Before.@Test.@After.@AfterClass这些注解,这些在应付普通简单的单元测试已经足够,然而有很多更加复杂且也会经常遇到的测试需求依靠这些生命周期注解并不能完成!因此这篇分

  • Python高级用法总结

    列表推导(list comprehensions) 场景1:将一个三维列表中所有一维数据为a的元素合并,组成新的二维列表. 最简单的方法:新建列表,遍历原三维列表,判断一维数据是否为a,若为a,则将该元素append至新列表中. 缺点:代码太繁琐,对于Python而言,执行速度会变慢很多. 针对场景1,我们首先应该想到用列表解析式来解决处理,一行代码即可解决: lista = [item for item in array if item[0] == 'a'] 那么,何为列表解析式? 官方解释:

  • MyBatis动态SQL标签的用法详解

    1.MyBatis动态SQL MyBatis 的强大特性之一便是它的动态 SQL,即拼接SQL字符串.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么痛苦.拼接的时候要确保不能忘了必要的空格,还要注意省掉列名列表最后的逗号.利用动态 SQL 这一特性可以彻底摆脱这种痛苦. 通常使用动态 SQL 不可能是独立的一部分,MyBatis 当然使用一种强大的动态 SQL 语言来改进这种情形,这种语言可以被用在任意的 SQL 映射语句中. 动态 SQL 元素和

  • gojs一些实用的高级用法

    目录 1. 取消更新动画 2. 导出图(含可视区外的部分) 3. 禁用 ctrl 相关快捷键 4. 画布滚动模式,无限滚动 or 局部滚动 5. 展开收起多层嵌套的组 6. 给图元素加动画 7. 修改框选的样式 1. 取消更新动画 问题:更新数据的时候,会触发渲染,有渲染动画,用户体验不好. 方案:初始数据绘制,有动画:更新数据绘制,无动画. 代码实现: // 后面所用到的 diagram 都是 gojs 创建的实例 // diagram_container 为图容器dom id diagram

随机推荐