MyBatis中的if判断的问题 ,存在误区

发布时间:2024-11-25 03:17

[汽车] 如何判断车辆是否存在漏油问题 #生活技巧# #汽车维修#

最新推荐文章于 2024-08-27 11:16:36 发布

ZhuangYQ丶 于 2018-09-07 10:29:07 发布

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

在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不会被解析。
总结下使用方法:单个的字符要写到双引号里面或者使用.toString()才行!

网址:MyBatis中的if判断的问题 ,存在误区 https://www.yuejiaxmz.com/news/view/249130

相关内容

Mybatis
python if是如何判断true或False的呢? is和== 有什么区别呢?
python 判断字符串是否相等 ==,is, in 误区。
如何判断一个数是否为2的N次方
Java解决if(!=null)臭名昭著的判空处理(Optional)
转:mybatis if test 不为空字符串或null
判断两个Integer是否相等,使用==会产生的问题分析
MySQL实现序列(Sequence)效果以及在Mybatis中如何使用这种策略
if(list != null && list.size() > 0)优化,集合判空优雅的实现方式
基于uniapp小程序的大学校园旧物捐赠网站附带文章源码部署视频讲解等

随便看看