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

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

1)resultMap参数

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

                

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

    select     from product_tab  

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

2)resultType参数

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

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

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

  • 表中的字段要么和实体类字段一致。
  • 如果表中字段带下划线,实体类中对应的字段不想带下划线,就要满足下划线转驼峰的方式,例如,表中字段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