在UserInfoMapper.xml中,增加如下内容:
-
<select id="findUserInfoByOneParam" parameterType="Map" resultMap="UserInfoResult">
-
select * from userinfo
-
<choose>
-
<when test="searchBy=='department'">
-
where department=#{department}
-
</when>
-
<when test="searchBy=='position'">
-
where position=#{position}
-
</when>
-
<otherwise>
-
where gender=#{gender}
-
</otherwise>
-
</choose>
-
</select>
【解释】
a.请注意这里的【select * from userinfo 】之后没有再写where语句
b.<choose><when><otherwise>配合使用是等价于java中的
-
if(...){
-
....
-
}else if(...){
-
...
-
}else{
-
....
-
}
c.按照官方文档给的示例,最后的<otherwise>是需要存在的,但是经过测试,即使最后的<otherwise>没有写,Mybatis也不会发生任何异常。而是将所有表数据返回。这是一种极为不推荐的做法。实际生产环境下,如果该表的数据量非常大,这条语句被执行,就是一个巨大的坑!
d.请注意观察;这里的“searchBy”是一个自定义的字符串,读者也可以按照自己的命名习惯,重新定义
e.再特别说明一下,请注意,每一个等号后面的参数都带有单引号。这是这种用法必须必须必须有的。否则,就是直接抛异常!
f.针对d,这里有另外一种情况那就是,判断null的键值对。具体写法如下:【这段代码,各位看官也可以顺便测试一下没有<otherwise>的执行结果是什么】
-
<select id="findUserInfoByOneParam" parameterType="Map" resultMap="UserInfoResult">
-
select * from userinfo
-
<choose>
-
<when test="department!=null">
-
where department=#{department}
-
</when>
-
<when test="position!=null">
-
where position=#{position}
-
</when>
-
</choose>
-
</select>
g.上面这段代码,还有一个值得注意的地方就是,两个when之间的顺序是有关系的。即,如果第一个when满足条件,第二个就不会影响查询结果,其他类似,请读者自行尝试,观察控制台输出。
h.最后,补充一点,就是<choose>的子元素就只能包含<when><otherwise>
最后
以上就是暴躁导师最近收集整理的关于Mybatis最入门---动态查询(choose,when,otherwise)的全部内容,更多相关Mybatis最入门---动态查询(choose内容请搜索靠谱客的其他文章。
发表评论 取消回复