软件编程
位置:首页>> 软件编程>> java编程>> mybatis中<if>标签bool值类型为false判断方法

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

作者:java欧阳丰  发布时间:2023-11-20 11:28:33 

标签:mybatis,if标签,bool

昨天实现一个功能,根据文章的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类型错误。

来源:https://www.jianshu.com/p/1165cb122e70

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com