mybatis中标签bool值类型为false判断方法
昨天实现一个功能,根据文章的id或者别名查找文章。
起初采用mybatis的Example进行查询,对参数artName进行判断,如果是纯数字就byId查询,否则就by别名。由于查询文章的同时,需要关联查询文章分类标签,所以选择采用select语句映射的方式查询,但又不想写两个查询方法,就使用了mybatis中动态sql。
/** *查询文章 *@paramartNameid或别名 *@parambyId如果是true则按照id查询 *否则按照别名查询 *@return */ publicArticleselectByArtName(@Param(value="artName")StringartName, @Param(value="byId")BooleanbyId);
mapper中定义了一个方法,有artName和byId两个参数,artName表示id或别名,byId表示是否通过id查询。
对byIdBoolean值进行判断时,出现false值无效的情况,在百度了一圈发现,普遍采用
a.id=#{artName}
这种方式,当byId=true时正常执行,但为false时不生效。后采用
a.id=#{artName} a.alias=#{artName}
byId本身是bool值,不用进行判断。
注意:byId不用加#{},不然false也会无效,如果加了#{},在与其他值进行比较时,
如:#{byId}==true会报空指针错误,如果写成#{byId}=='true' 会报Linkhashmap无法转换成String类型错误。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对毛票票的支持。