zoukankan      html  css  js  c++  java
  • mybatis 中标签bool值类型为false判断

    对百度的某些文章深恶痛绝, 只是ctrl+c和ctrl+v。并且还不能解决问题。

    昨天实现一个功能,根据文章的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>
    <when test="byId">
    a.id = #{artName}
    </when>
    <otherwise>
    a.alias = #{artName}
    </otherwise>
    </choose>

    byId本身是bool值,不用进行判断。
    注意: byId不用加#{},不然false也会无效,如果加了#{}, 在与其他值进行比较时,
    如:#{byId} == true 会报空指针错误,如果写成#{byId} == ‘true’ 会报Linkhashmap无法转换成String类型错误。
    ————————————————
    版权声明:本文为CSDN博主「欧阳丰」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/lonely_bin/article/details/98751584

  • 相关阅读:
    02_排版标记
    21_listview展示数据内容回顾
    00_前情回顾
    20_通过listview展示数据库数据_完成
    18_simpleadapter和ArrayAdapter总结
    19_通过listview展示数据库数据_数据库准备数据完成
    前端面试题-url、href、src
    前端面试题-url、href、src
    前端面试题-url、href、src
    这8个方法让你成为最优秀的程序员
  • 原文地址:https://www.cnblogs.com/telwanggs/p/12486612.html
Copyright © 2011-2022 走看看