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

分手后的思念是犯贱 2021-09-26 05:34 475阅读 0赞

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

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

原来的写法:

  1. <select id="selectByArticle" parameterType="com.pet.bean.Article" resultMap="com.pet.bean.Article">
  2. SELECT <include refid="Base_Column_List"/>
  3. FROM ARTICLE
  4. <where>
  5. <include refid="com.pet.mapper.ArticleMapper.queryCondition" />
  6. </where>
  7. </select>
  8. <sql id="queryCondition">
  9. <if test="@org.apache.commons.lang.StringUtils@isNotBlank(id)">AND ID = #{id,jdbcType=Integer}</if>
  10. <if test="@org.apache.commons.lang.StringUtils@isNotBlank(authorName)">AND AUTHOR_NAME = #{authorName,jdbcType=VARCHAR}</if>
  11. <if test="@org.apache.commons.lang.StringUtils@isNotBlank(title)">AND TITLE = #{title,jdbcType=VARCHAR}</if>
  12. <if test="@org.apache.commons.lang.StringUtils@isNotBlank(content)">AND CONTENT = #{content,jdbcType=VARCHAR}</if>
  13. <if test="@org.apache.commons.lang.StringUtils@isNotBlank(makeTime)">AND MAKE_TIME = #{makeTime,jdbcType=VARCHAR}</if>
  14. <if test="@org.apache.commons.lang.StringUtils@isNotBlank(updateTime)">AND UPDATE_TIME = #{updateTime,jdbcType=VARCHAR}</if>
  15. <if test="@org.apache.commons.lang.StringUtils@isNotBlank(kind)">AND KIND = #{kind,jdbcType=VARCHAR}</if>
  16. <if test="@org.apache.commons.lang.StringUtils@isNotBlank(about)">AND ABOUT = #{about,jdbcType=VARCHAR}</if>
  17. <if test="@org.apache.commons.lang.StringUtils@isNotBlank(status)">AND STATUS = #{status,jdbcType=VARCHAR}</if>
  18. </sql>

部分代码:

Center

日志显示:

Center 1

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

  1. <select id="selectByArticle" parameterType="com.pet.bean.Article" resultMap="BaseResultMap">
  2. SELECT <include refid="Base_Column_List"/>
  3. FROM ARTICLE
  4. <where>
  5. <include refid="com.pet.mapper.ArticleMapper.queryCondition" />
  6. </where>
  7. </select>
  8. <resultMap id="BaseResultMap" type="com.pet.bean.Article" >
  9. <id column="ID" property="id" jdbcType="INTEGER" />
  10. <result column="AUTHOR_NAME" property="authorName" jdbcType="VARCHAR" />
  11. <result column="TITLE" property="title" jdbcType="VARCHAR" />
  12. <result column="CONTENT" property="content" jdbcType="VARCHAR" />
  13. <result column="MAKE_TIME" property="makeTime" jdbcType="VARCHAR" />
  14. <result column="UPDATE_TIME" property="updateTime" jdbcType="VARCHAR" />
  15. <result column="KIND" property="kind" jdbcType="VARCHAR" />
  16. <result column="ABOUT" property="about" jdbcType="VARCHAR" />
  17. </resultMap>

日志显示:

Center 2

发表评论

表情:
评论列表 (有 0 条评论,475人围观)

还没有评论,来说两句吧...

相关阅读

    相关 SQL语句部分执行顺序

    sql语法的分析是从右到左 一、sql语句的执行步骤: 1)语法分析,分析语句的语法是否符合规范,衡量语句中各表达式的意义。 2)语义分析,检查语句中涉及的所有数据库对象

    相关 mybatis执行sql语句

    写在前面 通过[这篇文章][Link 1]的分析,已经生成了可以执行的sql语句了,本文来分析SQL语句具体的执行过程。 想要系统学习的,可以参考[这篇文章,重要!!

    相关 Mybatis 动态执行SQL语句

    有很多的接口都只是执行个SQL查询之后就直接返回给前端,那么我们能不能把这些SQL保存在数据库中,调用一个固定的接口就能根据传参查询出想要的数据呢?或者当为了加减个字段就得修改