在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内容请搜索靠谱客的其他文章。
发表评论 取消回复