mybatis(如何判断list集合是否包含指定数据)
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中双引号需要用转义字符",所以比较字符串必须有这种方式:
<if test="list.contains("0")"> #{逻辑} </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)
以上为个人经验,希望能给大家一个参考,也希望大家多多支持趣讯吧。
推荐阅读
-
Mybatis中怎么利用useGeneratedKeys获取自增主键
Mybatis中怎么利用useGeneratedKeys获取自增主键,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以...
-
Mybatis中怎么实现SQL防注入
这篇文章给大家介绍Mybatis中怎么实现SQL防注入,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。什么是S...
-
mybatis中怎么利用注解对对象进行批量更改
这期内容当中小编将会给大家带来有关mybatis中怎么利用注解对对象进行批量更改,文章内容丰富且以专业的角度为大家分析和叙述,阅读...
-
Mybatis如何自动生成数据库表的实体类
-
Mybatis中多个对象包含同一个对象的处理操作
-
mybatis配置对象包含对象以及List的方式
mybatis配置对象包含对象以及List的方式mybatis配置对象包含对象及List这里隐藏getset方法publ...
-
Mybatis中resultMap如何使用
-
如何使用mybatis查询语句
本篇文章给大家分享的是有关如何使用mybatis查询语句,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收...
-
解决mybatis中的mapper命名问题
mybatismapper命名问题mapper文件中id命名最好首字母小写,避免让mybatis认为是一个类<...
-
SelectKey怎么在Mybatis中应用