您好,登录后才能下订单哦!
这篇文章主要介绍了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类型错误。
感谢你能够认真阅读完这篇文章,希望小编分享的“mybatis中怎么判断<if>标签bool值类型为false”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。