MyBatis中的if判断存在的误区[参考总结博文]

项目中使用mybatis,使用if标签来判断是否需要分页还是导出,如果传入的是0则分页,1则不分页;

此处存在两种情况:

1.0是int(或者是Integer);

2.当0是String;

 

1.当0是int(或者是Integer):  https://blog.csdn.net/mnijafon/article/details/75623397

具体信息如下:

dao方法参数:List<TTransRequestEntity> getDataGrid(@Param("end") int end);

mapper.xml配置:<if test="end != '' ">limit #{first},#{end}</if>

经过测试,当传入的end=0时,如果在mapper中使用<if test="end != null ">limit #{first},#{end}</if>判断是true,这样输出的sql就是limit 0,0.

当当传入的end=0时,mapper为<if test="end != '' ">limit #{first},#{end}</if>判断为false,limit语句不进入.

查看输出的mybatis信息发现,尽管在dao方法中设置的为int类型,但是mybatis使用的却是Integer.mybatis把0处理成'',也就是空字符串而不是null.

使用的是mybatis3.4.1版本.

 

2.当0是String:  https://blog.csdn.net/iilegend/article/details/82492412
 

在MyBatis的mapp文件中的if判断中是这样写的

<if test="type == '0' ">
              and so1.id =  #{unitcode}
         </if>
导致出现的问题就是根本没有进去这个if判断中,所以条件 and so1.id =  #{unitcode} 也没有加上。导致不执行if判断中的sql,运行程序不报错,没有任何提示。去掉takeWay == “1” and 则可执行。对此我百思不得其解,

   后来大神帮我改正:

 <if test= "type == '0'.toString() ">
        and so1.id =  #{unitcode}
 </if>

或者改成:

 <if test= 'type == "0" '>
        and so1.id =  #{unitcode}
 </if>

这样就可以使用了。

原理分析:

mybatis是用OGNL表达式来解析的,在OGNL的表达式中,’1’会被解析成字符,java是强类型的,char 和 一个string 会导致不等,所以if标签中的sql不会被解析。
总结下使用方法:当0是int[Integer]是mybatis解析成'', 当0是String等值条件是:"0" 或者'0'.toString(),不能写'0';

 

 


 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值