mybatis中<if>标签bool值类型为false判断方法
昨天实现一个功能,根据文章的id或者别名查找文章。
起初采用mybatis的Example进行查询,对参数artName进行判断,如果是纯数字就byId查询,否则就by别名。由于查询文章的同时,需要关联查询文章分类标签,所以选择采用select语句映射的方式查询,但又不想写两个查询方法,就使用了mybatis中动态sql。
/**
* 查询文章
* @param artName id 或 别名
* @param byId 如果是 true 则按照id查询
* 否则 按照别名查询
* @return
*/
public Article selectByArtName(@Param(value = "artName") String artName,
@Param(value = "byId") Boolean byId);
mapper中定义了一个方法,有artName和byId两个参数,artName 表示id 或 别名,byId表示是否通过id查询。
对byId Boolean值进行判断时,出现false值无效的情况,在百度了一圈发现,普遍采用
<if test="byId != null">
a.id = #{artName}
</if>
这种方式,当byId=true时正常执行,但为false时不生效。后采用<choose>标签
<choose>
<when test="byId">
a.id = #{artName}
</when>
<otherwise>
a.alias = #{artName}
</otherwise>
</choose>
byId本身是bool值,不用进行判断。
注意: byId不用加#{},不然false也会无效,如果加了#{}, 在与其他值进行比较时,
如: #{byId} == true 会报空指针错误,如果写成#{byId} == 'true' 会报Linkhashmap无法转换成String类型错误。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。
相关文章
从最基本的Java工程搭建SpringMVC+SpringDataJPA+Hibernate
本文会介绍从一个最基本的java工程,到Web工程,到集成Spring、SpringMVC、SpringDataJPA+Hibernate,本文介绍的非常详细,具有参考借鉴价值,感兴趣的朋友一起学习吧2016-05-05
springboot rabbitmq整合rabbitmq之消息持久化存储问题
这篇文章主要介绍了springboot rabbitmq整合rabbitmq之消息持久化存储问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-09-09
Mybatis foreach用法解析--对于list和array
这篇文章主要介绍了Mybatis foreach用法解析--对于list和array,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-03-03
SpringBoot与spring security的结合的示例
这篇文章主要介绍了SpringBoot与spring security的结合的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-03-03


最新评论