Mybatis查询Sql结果未映射到对应得实体类上的问题解决
作者:JYWWABF
使用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结果未映射内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!