mybatis中<if>标签bool值类型为false判断方法

网友投稿 258 2022-12-31


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值无效的情况,在百度了一圈发现,普遍采用

a.id = #{artName}

这种方式,当byId=true时正常执行,但为false时不生效。后采用标签

a.id = #{artName}

a.alias = #{artName}

byId本身是bool值,不用进行判断。

注意: byId不用加#{},不然false也会无效,如果加了#{}, 在与其他值进行比较时,

如: #{byId} == true 会报空指针错误,如果写成#{byId} == 'true'   会报Linkhashmap无法转换成String类型错误。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。


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

上一篇:可以使用的接口测试工具(适用于接口测试的工具)
下一篇:实现接口要重写所有方法吗(java重写接口方法)
相关文章

 发表评论

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