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结果未映射内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 利用SpringBoot实现多数据源的两种方式总结

    利用SpringBoot实现多数据源的两种方式总结

    关于动态数据源的切换的方案有很多,核心只有两种,一种是构建多套环境,另一种是基于spring原生的AbstractRoutingDataSource切换,这篇文章主要给大家介绍了关于利用SpringBoot实现多数据源的两种方式,需要的朋友可以参考下
    2021-10-10
  • java数组、泛型、集合在多态中的使用及对比

    java数组、泛型、集合在多态中的使用及对比

    本文主要介绍了java数组、泛型、集合在多态中的使用及对比。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-03-03
  • java短信验证码获取次数限制实例

    java短信验证码获取次数限制实例

    这篇文章主要介绍了java短信验证码获取次数限制实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • Java实现简单双色球摇奖功能过程解析

    Java实现简单双色球摇奖功能过程解析

    这篇文章主要介绍了Java实现简单双色球摇奖功能过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-09-09
  • MyBatis字段名和属性名不一致的解决方法

    MyBatis字段名和属性名不一致的解决方法

    本文主要介绍了MyBatis字段名和属性名不一致的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • 基于Springboot2.0构建ES的多客户端

    基于Springboot2.0构建ES的多客户端

    这篇文章主要为大家详细介绍了基于Springboot2.0构建ES的多客户端,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-04-04
  • java eclipse 出现 xxx cannot be resolved to a type 错误解决方法

    java eclipse 出现 xxx cannot be resolved to a type 错误解决方法

    这篇文章主要介绍了java eclipse 出现 xxx cannot be resolved to a type 错误解决方法的相关资料,需要的朋友可以参考下
    2017-03-03
  • Java多线程中的Phaser使用解析

    Java多线程中的Phaser使用解析

    这篇文章主要介绍了Java多线程中的Phaser使用解析,java多线程技术提供了Phaser工具类,Phaser表示“阶段器”,用来解决控制多个线程分阶段共同完成任务的情景问题,其作用相比CountDownLatch和CyclicBarrier更加灵活,需要的朋友可以参考下
    2023-11-11
  • 值得收藏的SpringBoot 实用的小技巧

    值得收藏的SpringBoot 实用的小技巧

    最近分享的一些源码、框架设计的东西。我发现大家热情不是特别高,想想大多数应该还是正儿八经写代码的居多;这次就分享一点接地气的: SpringBoot 使用中的一些小技巧 ,需要的朋友可以参考下
    2018-10-10
  • Jackson序列化和反序列化忽略字段操作

    Jackson序列化和反序列化忽略字段操作

    这篇文章主要介绍了Jackson序列化和反序列化忽略字段操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09

最新评论