Mybatis最入门---动态查询(choose,when,otherwise)

在UserInfoMapper.xml中,增加如下内容:

 

 

 
  1. <select id="findUserInfoByOneParam" parameterType="Map" resultMap="UserInfoResult">

  2. select * from userinfo

  3. <choose>

  4. <when test="searchBy=='department'">

  5. where department=#{department}

  6. </when>

  7. <when test="searchBy=='position'">

  8. where position=#{position}

  9. </when>

  10. <otherwise>

  11. where gender=#{gender}

  12. </otherwise>

  13. </choose>

  14. </select>

【解释】

 

a.请注意这里的【select * from userinfo 】之后没有再写where语句

b.<choose><when><otherwise>配合使用是等价于java中的

 
  1. if(...){

  2. ....

  3. }else if(...){

  4. ...

  5. }else{

  6. ....

  7. }

c.按照官方文档给的示例,最后的<otherwise>是需要存在的,但是经过测试,即使最后的<otherwise>没有写,Mybatis也不会发生任何异常。而是将所有表数据返回。这是一种极为不推荐的做法。实际生产环境下,如果该表的数据量非常大,这条语句被执行,就是一个巨大的坑!

 

d.请注意观察;这里的“searchBy”是一个自定义的字符串,读者也可以按照自己的命名习惯,重新定义

e.再特别说明一下,请注意,每一个等号后面的参数都带有单引号。这是这种用法必须必须必须有的。否则,就是直接抛异常!

f.针对d,这里有另外一种情况那就是,判断null的键值对。具体写法如下:【这段代码,各位看官也可以顺便测试一下没有<otherwise>的执行结果是什么】

 

 
  1. <select id="findUserInfoByOneParam" parameterType="Map" resultMap="UserInfoResult">

  2. select * from userinfo

  3. <choose>

  4. <when test="department!=null">

  5. where department=#{department}

  6. </when>

  7. <when test="position!=null">

  8. where position=#{position}

  9. </when>

  10. </choose>

  11. </select>

g.上面这段代码,还有一个值得注意的地方就是,两个when之间的顺序是有关系的。即,如果第一个when满足条件,第二个就不会影响查询结果,其他类似,请读者自行尝试,观察控制台输出。

h.最后,补充一点,就是<choose>的子元素就只能包含<when><otherwise>

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值