- 需求
- 在mybatis脚本中想要判断list中是否含有某个字符串。
- 动态使用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>