Mybatis查询Sql结果未映射到对应得实体类上的问题解决

 更新时间:2024年02月04日 09:55:02   作者:JYWWABF  
使用mybatis查询表数据得时候,发现对应得实体类字段好多都是null,本文主要介绍了Mybatis查询Sql结果未映射到对应得实体类上的问题解决,具有一定的参考价值,感兴趣的可以了解一下

使用mybatis查询表数据得时候,已经确定sql语句没问题,可以正常查询出结果,但是使用实体类接收的时候,发现对应得实体类字段好多都是null。也就是说有些字段没有映射到实体类上

首先,mybatis与实体类的映射方式,主要是有两种。不同的映射方式,也对应不同的接收方式

1)resultMap参数

通过编写resultMap。如下将数据库字段和实体类字段进行映射。其中,column为数据库字段,property为实体类字段。

<resultMap id="BaseResultMap" type="com.**.job.model.Product">
    <id column="id" jdbcType="VARCHAR" property="id" />
    <result column="create_time" jdbcType="TIMESTAMP" property="createTime" />
    <result column="update_time" jdbcType="TIMESTAMP" property="updateTime" />
    <result column="version" jdbcType="INTEGER" property="version" />
</resultMap>

如果采用这种方式映射,那么查询时,返回类型就可以用restMap的id进行接收。将select标签中的接收参数设置为resultMap = "BaseResultMap"。

<select id="findAll" resultMap="BaseResultMap">
    select <include refid="Base_Column_List" />
    from product_tab
  </select>

如果此时你使用resultType属性接受,有可能就会造成某些实体类字段接收不到值,显示为null

2)resultType参数

如果不想编写resultMap,我们也可以使用select 标签中的resultType进行接收。

此时resultType 指向具体的实体类。

<select id="selectByDto" resultType="com.**.job.model.Product">

但是这种需要满足下面两个条件之一:

  • 表中的字段要么和实体类字段一致。
  • 如果表中字段带下划线,实体类中对应的字段不想带下划线,就要满足下划线转驼峰的方式,例如,表中字段product_url,实体类中的字段,要写成productUrl。

如果以上两个条件都满足,还是出现某些实体类字段为null。就去检查一下是否设置了mybatis的mapUnderscoreToCamelCase参数。该参数默认为false。

将这个属性设置为true。 可以自动将以下画线方式命名的数据库列映射到 Java 对象的驼峰式命名属性中。

设置方式如下:

总结如下:

1)如果你写了resultMap 的xml映射,那么select标签的属性选择resultMap。

2)如果你没写resultMap 的xml映射,那也没事。mybatis会自动帮你映射。但是你的select标签的属性要resultType,用于指向具体的实体类。但同时,你要满足上面两点条件。同时确保mapUnderscoreToCamelCase参数为true

建议编写resultMap,只要映射没错,基本上不会出现为null的情况,实体类的字段可以随便写。

当然如果你库表中的字段很多的话,可以使用mybatis-generator生成工具,直接生成resultMap的xml

到此这篇关于Mybatis查询Sql结果未映射到对应得实体类上的问题解决的文章就介绍到这了,更多相关Mybatis查询Sql结果未映射内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 深入解读分布式事务Seata的XA模式

    深入解读分布式事务Seata的XA模式

    这篇文章主要介绍了深入解读分布式事务Seata的XA模式,XA 规范 描述了全局的事务管理器与局部的资源管理器之间的接口,XA规范 的目的是允许的多个资源在同一事务中访问,这样可以使 ACID 属性跨越应用程序而保持有效,需要的朋友可以参考下
    2023-08-08
  • HttpClient连接池及重试机制解析

    HttpClient连接池及重试机制解析

    这篇文章主要介绍了HttpClient连接池及重试机制解析,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • 如何通过Maven仓库安装Spire系列的Java产品

    如何通过Maven仓库安装Spire系列的Java产品

    这篇文章主要介绍了如何通过Maven仓库安装Spire系列的Java产品,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-07-07
  • Java实现常见的排序算法的示例代码

    Java实现常见的排序算法的示例代码

    这篇文章主要为大家详细介绍了Java实现常见的排序算法(选择排序、插入排序、希尔排序等)的相关资料,文中的示例代码讲解详细,感兴趣的可以了解一下
    2022-10-10
  • SpringBoot HikariCP连接池详解

    SpringBoot HikariCP连接池详解

    这篇文章主要介绍了SpringBoot2.0 中 HikariCP 数据库连接池原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • Intellij Idea中进行Mybatis逆向工程的实现

    Intellij Idea中进行Mybatis逆向工程的实现

    这篇文章主要介绍了Intellij Idea中进行Mybatis逆向工程的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • SpringBoot项目实战之数据交互篇

    SpringBoot项目实战之数据交互篇

    这篇文章主要给大家介绍了关于SpringBoot项目实战之数据交互篇的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-03-03
  • 简单了解Spring中常用工具类

    简单了解Spring中常用工具类

    这篇文章主要介绍了简单了解Spring中常用工具类,非常全面,具有一定参考价值,需要的朋友可以了解下。
    2017-10-10
  • java实现2048小游戏(含注释)

    java实现2048小游戏(含注释)

    这篇文章主要为大家介绍了java实现2048小游戏,含详细注释,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • IntelliJ IDEA 2022.2.3最新激活图文教程(亲测有用永久激活)

    IntelliJ IDEA 2022.2.3最新激活图文教程(亲测有用永久激活)

    今天给大家分享一个 IDEA 2022.2.3 的激活破解教程,全文通过文字+图片的方式讲解,手把手教你如何激活破解 IDEA, 只需要几分钟即可搞定,对idea2022.2.3激活码感兴趣的朋友跟随小编一起看看吧
    2022-11-11

最新评论