iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >mybatis 如何判断list集合是否包含指定数据
  • 856
分享到

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

2024-04-02 19:04:59 856人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

需求 1、在mybatis脚本中想要判断list中是否含有某个字符串。 2、动态使用list中的属性,添加到数据库crud字段。 网上也没搜到类似的案例,配置choose功能,可以方

需求

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)

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

--结束END--

本文标题: mybatis 如何判断list集合是否包含指定数据

本文链接: https://www.lsjlt.com/news/128693.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mybatis 如何判断list集合是否包含指定数据
    需求 1、在mybatis脚本中想要判断list中是否含有某个字符串。 2、动态使用list中的属性,添加到数据库crud字段。 网上也没搜到类似的案例,配置choose功能,可以方...
    99+
    2024-04-02
  • javascript如何判断是否包含指定字符串
    这篇文章主要介绍“javascript如何判断是否包含指定字符串”,在日常操作中,相信很多人在javascript如何判断是否包含指定字符串问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望...
    99+
    2024-04-02
  • jquery如何判断元素是否包含指定类
    这篇文章主要介绍了jquery如何判断元素是否包含指定类的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇jquery如何判断元素是否包含指定类文章都会有所收获,下面我们一起来看看...
    99+
    2024-04-02
  • Java判断List集合中的对象是否包含有某一元素
    关于以下方法,直接可以在自己项目创建一个类,然后进行测试使用!文本末尾也提供了每个方法的运行结果,供大家参考使用! 文章大量使用到了Java8当中的Lambda表达式,以及stream流相关基础知...
    99+
    2023-08-31
    java
  • javascript怎样判断是否包含指定字符串
    本篇文章给大家分享的是有关javascript怎样判断是否包含指定字符串,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。判断方法:1、使用ind...
    99+
    2024-04-02
  • JavaScript如何判断是否包含值
    这篇文章主要为大家展示了“JavaScript如何判断是否包含值”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript如何判断是否包含值”这篇文章吧...
    99+
    2024-04-02
  • containsKey方法——判断是否包含指定的键名
    containsKey方法是Map接口中的一个方法,用于判断是否包含指定的键名。语法:boolean containsKey(Obj...
    99+
    2023-09-12
    containsKey
  • es6如何判断数组中是否包含对象
    今天小编给大家分享一下es6如何判断数组中是否包含对象的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了...
    99+
    2024-04-02
  • jquery如何判断是否包含某属性
    本文小编为大家详细介绍“jquery如何判断是否包含某属性”,内容详细,步骤清晰,细节处理妥当,希望这篇“jquery如何判断是否包含某属性”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。实现步骤:1、使用jque...
    99+
    2023-07-04
  • javascript如何判断指定值是否是偶数
    本篇内容主要讲解“javascript如何判断指定值是否是偶数”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript如何判断指定值是否是偶数”吧! ...
    99+
    2024-04-02
  • java如何判断集合是否重复
    在Java中,可以通过以下方法来判断集合中是否存在重复的元素: 使用Set集合:Set是集合的一种,它不允许重复元素。因此,可以将...
    99+
    2024-04-02
  • es6如何判断数组是否包含某个元素
    ES6中可以使用includes()方法来判断一个数组是否包含某个元素。这个方法返回一个布尔值,表示数组是否包含指定的元素。语法如下...
    99+
    2023-10-07
    es6
  • Python如何判断字符串是否仅包含数字
      在用Python进行数据处理的时候,经常会遇到DataFrame中的某一列本应该是数值类型,但由于数据不规范导致在字段中夹杂了非数值类型。对于这种类型的数据,...
    99+
    2024-04-02
  • 如何判断json中是否包含某个值
    要判断一个 JSON 对象中是否包含某个值,可以使用以下方法:1. 将 JSON 字符串转换为对象使用 JSON.parse() 方...
    99+
    2023-09-29
    json
  • JS 中判断数组是否包含指定元素的方法有哪些
    这篇文章主要讲解了“JS 中判断数组是否包含指定元素的方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JS 中判断数组是否包含指定元素的方法有哪些”...
    99+
    2024-04-02
  • php怎么判断数组中是否包含指定元素(方法浅析)
    PHP是一种脚本语言,广泛用于Web开发中。在PHP中,数组是一种非常重要的数据类型,可用于存储多个值。在PHP中,有时需要判断一个数组是否包含某个元素。本文将介绍一些方法用于判断PHP数组是否包含元素。in_array()函数in_arr...
    99+
    2023-05-14
  • javascript如何判断指定值是否为正数
    这篇文章主要介绍了javascript如何判断指定值是否为正数的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇javascript如何判断指定值是否为正数文章都会有所收获,下面我...
    99+
    2024-04-02
  • es6如何判断数组中是否包含某一项值
    小编给大家分享一下es6如何判断数组中是否包含某一项值,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! 在es6中,可以利用数组的includes()方法来判断数...
    99+
    2024-04-02
  • delphi如何判断字符串是否包含汉字
    这篇“delphi如何判断字符串是否包含汉字”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“delphi如何判断字符串是否包含...
    99+
    2023-07-04
  • jquery如何判断是否包含某个id元素
    这篇文章主要介绍了jquery如何判断是否包含某个id元素,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 方法:...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作