解决mybatis执行SQL语句部分参数返回NULL问题

2025-05-29 0 59

今天在写代码的时候发现一个问题:mybatis执行sql语句的时候返回bean的部分属性为null,在数据库中执行该sql语句能够正常返回,把相关代码反反复复翻了个遍,甚至都重启eclipse了,依旧没解决问题,后来网上搜了一下,还真有类似的问题。

闲话少说,直接说问题,该sql语句是自己写的,resultType直接用了该bean全名称,最终导致部分属性显示为null,

原来的写法:

  1. <selectid="selectByArticle"parametertype="com.pet.bean.Article"resultmap="com.pet.bean.Article">
  2. SELECT
  3. FROMARTICLE
  4. </select>
  5. <sqlid="queryCondition">
  6. <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(id)">ANDID=#{id,jdbcType=Integer}</if>
  7. <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(authorName)">ANDAUTHOR_NAME=#{authorName,jdbcType=VARCHAR}</if>
  8. <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(title)">ANDTITLE=#{title,jdbcType=VARCHAR}</if>
  9. <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(content)">ANDCONTENT=#{content,jdbcType=VARCHAR}</if>
  10. <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(makeTime)">ANDMAKE_TIME=#{makeTime,jdbcType=VARCHAR}</if>
  11. <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(updateTime)">ANDUPDATE_TIME=#{updateTime,jdbcType=VARCHAR}</if>
  12. <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(kind)">ANDKIND=#{kind,jdbcType=VARCHAR}</if>
  13. <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(about)">ANDABOUT=#{about,jdbcType=VARCHAR}</if>
  14. <iftest="@org.apache.commons.lang.StringUtils@isNotBlank(status)">ANDSTATUS=#{status,jdbcType=VARCHAR}</if>
  15. </sql>

部分代码:

解决mybatis执行SQL语句部分参数返回NULL问题

日志显示:

解决mybatis执行SQL语句部分参数返回NULL问题

修改后的写法:resultType改成了resultMap了

  1. <selectid="selectByArticle"parametertype="com.pet.bean.Article"resultmap="BaseResultMap">
  2. SELECT
  3. FROMARTICLE
  4. </select>
  5. <resultmapid="BaseResultMap"type="com.pet.bean.Article">
  6. <idcolumn="ID"jdbctype="INTEGER"property="id">
  7. <resultcolumn="AUTHOR_NAME"jdbctype="VARCHAR"property="authorName">
  8. <resultcolumn="TITLE"jdbctype="VARCHAR"property="title">
  9. <resultcolumn="CONTENT"jdbctype="VARCHAR"property="content">
  10. <resultcolumn="MAKE_TIME"jdbctype="VARCHAR"property="makeTime">
  11. <resultcolumn="UPDATE_TIME"jdbctype="VARCHAR"property="updateTime">
  12. <resultcolumn="KIND"jdbctype="VARCHAR"property="kind">
  13. <resultcolumn="ABOUT"jdbctype="VARCHAR"property="about">
  14. </result></result></result></result></result></result></result></id></resultmap>

日志显示:

解决mybatis执行SQL语句部分参数返回NULL问题

以上所述是小编给大家介绍的解决mybatis执行SQL语句部分参数返回NULL问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对快网idc网站的支持!

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 解决mybatis执行SQL语句部分参数返回NULL问题 https://www.kuaiidc.com/116291.html

相关文章

发表评论
暂无评论