mybatis 如何判断list集合是否包含指定数据

 更新时间:2021年06月21日 11:04:14   作者:yyoc97  
这篇文章主要介绍了mybatis 判断list集合是否包含指定数据的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

需求

1、在mybatis脚本中想要判断list中是否含有某个字符串。

2、动态使用list中的属性,添加到数据库crud字段。

网上也没搜到类似的案例,配置choose功能,可以方便做写动态sql拼装,所以记录下。

准备

之前脚本中用的最多的list函数就是size和遍历了。那么mybatis脚本中是不是又包含函数了。首先我们要清楚list的类型。写个简单的测试用例。

<select id="test" parameterType="java.util.Map" resultType="java.util.Map">
        select
          <if test="list.containsKey('0')">
              'yes' as a,
          </if>
          1
    </select>

在list后接一个方法containsKey,运行后会抛出一个异常:

Caused by: org.apache.ibatis.ognl.MethodFailedException: Method "containsKey" failed for object [0, 1] [java.lang.NoSuchMethodException: java.util.Arrays$ArrayList.containsKey(java.lang.Character)]

我们可以看到list的类型为:ArrayList,它没有containsKey方法,但是我们知道List应该有contains()方法,是的没错。不过脚本在计算大小时size是不用加()的,加上还会抛异常。

细节

上面异常中还有一个细节就是containsKey(java.lang.Character),Character在java里面是字符类型的,也就是List中如果是存的[0,1]或则[“0”,“1”],那么多少匹配不到了,比较整数只能是contains(0),比较字符串只能是双引号,而不能是单引号,因为java做了强制类型比较,而mybatis中双引号需要用转义字符&quot;,所以比较字符串必须有这种方式:

 <if test="list.contains(&quot;0&quot;)">
              #{逻辑}
        </if>

从list动态取数

-- 插入字段直接从list中获取,通过${list[0].retainDay} 方式。

当然也可以将list封装到map里面,这样代码中就要多操作一步

<insert id="insert">
           insert ignore into ads_circle_user_retain
             (eventDate,${list[0].retainDay})
           VALUES
            <foreach collection="list" item="item" separator=",">
                (#{item.eventDate1},#{item.readNum})
            </foreach>
           on DUPLICATE KEY UPDATE ${list[0].retainDay} = values(${list[0].retainDay})
    </insert>

集合(list)判断是否存在对应的字符串或对象

判断集合中是否存在某个字符串对象,存在返回true,不存在返回false

list.contains("str1")

判断集合中时候存在完全一样的某个对象(所有属性都一样),存在返回true,不存在返回false

list.containsAll(Objcet obj)

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

相关文章

  • Spring的RedisTemplate存储的key和value有特殊字符的处理

    Spring的RedisTemplate存储的key和value有特殊字符的处理

    这篇文章主要介绍了Spring的RedisTemplate存储的key和value有特殊字符的处理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • 浅析Java模板方法的一种使用方式

    浅析Java模板方法的一种使用方式

    模板方法说白了就是将一段代码模板化,将通用的代码段抽取出来,并提供一些自定义的接口去定制的特定位置的某些业务功能。本文主要来和大家聊聊它的一种使用方式,希望对大家有所帮助
    2023-02-02
  • 学java得这样学,学习确实也得这样

    学java得这样学,学习确实也得这样

    学java得这样学,学习东西确实也得这样
    2008-02-02
  • 基于java构造方法Vector修改元素源码分析

    基于java构造方法Vector修改元素源码分析

    本篇文章是关于ava构造方法Vector源码分析系列文章,本文主要介绍了Vector修改元素的源码分析,有需要的朋友可以借鉴参考下,希望可以有所帮助
    2021-09-09
  • Java实现给网站上传图片盖章的方法

    Java实现给网站上传图片盖章的方法

    这篇文章主要介绍了Java实现给网站上传图片盖章的方法,涉及java针对图片的合成操作技巧,类似水印功能,需要的朋友可以参考下
    2015-07-07
  • SpringBoot实现文件的上传、下载和预览功能

    SpringBoot实现文件的上传、下载和预览功能

    在Spring Boot项目中实现文件的上传、下载和预览功能,可以通过使用Spring MVC的MultipartFile接口来处理文件上传,并使用HttpServletResponse或Resource来实现文件下载和预览,下面是如何实现这些功能的完整示例,需要的朋友可以参考下
    2024-08-08
  • 以Java代码的方式总结几个典型的内存溢出案例

    以Java代码的方式总结几个典型的内存溢出案例

    作为程序员,多多少少都会遇到一些内存溢出的场景,如果你还没遇到,说明你工作的年限可能比较短,或者你根本就是个假程序员!哈哈,开个玩笑.今天分享给大家Java内存溢出的相关案例,希望大家在日常工作中,尽量避免写这些low水平的代码,需要的朋友可以参考下
    2021-06-06
  • java 方法泛型入参T和String的重载关系详解

    java 方法泛型入参T和String的重载关系详解

    这篇文章主要介绍了java 方法泛型入参T和String的重载关系详解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • java设计模式之适配器模式(Adapter)

    java设计模式之适配器模式(Adapter)

    这篇文章主要介绍了java设计模式之适配器模式Adapter的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • spring boot 静态资源处理方法

    spring boot 静态资源处理方法

    本篇文章主要介绍了spring boot 静态资源处理方法。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03

最新评论