mybatis中 if

网友投稿 393 2022-07-26


目录if-test数字判断的坑mybatis的test判断注意事项

if-test数字判断的坑

在项目中偶然发现一个判断数字的if没有起任何作用,代码如下

AND

...

经过查询资料发现,mybatis是用OGNL表达式来解析的,在OGNL的表达式中,数字’3’会被解析成字符,java是强类型的,char 和 一个string 会导致不等,所以if标签中的sql不会被解析。

所以应该改为:

AND

...

然后发现确实解决了这个问题,特此记录。

mybatis的test判断注意事项

在使用mybatis进行判断的时候,一定要注意传入的数据类型与判断的目标值类型是否一致。

最近在一次开发过程,误将一个传入的整型数据使用了下面的判断方式:

http://

and a.c_appType = #{appType}

其中,appType是一个整型数据。可以看到,在test判断里面使用了 appType != '39;。

在进行业务功能测试的时候发现,当传入的值是0时,该条件筛选没有起作用,通过调试发现,mybatis会将空字符串转换成double类型的0.0,如下图所示:

同样的,整数数据也会转换为double类型,如下图所示:

所以,mybatis在判断的时候,数字0和空字符串是相等的,而我们的if判断里,是两者不相等时该条件才会WZYrqg起作用。

因此,在使用mybatis判断的时候,一定要注意类型是否一致,数字类型就不要判断空字符串的情况了。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java任务定时执行器案例的实现
下一篇:java使用JWT的方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~