项目中使用mybatis,使用if标签来判断是否需要分页还是导出,如果传入的是0则分页,1则不分页;
此处存在两种情况:
1.当0是int(或者是Integer);
2.当0是String;
1.当0是int(或者是Integer): https://blog.youkuaiyun.com/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.youkuaiyun.com/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';