MyBatis只能自动维护库表”列名“与”属性名“相同时的对应关系,二者不同时无法自动ORM
因此需要使用到ORM映射。
共有两种解决办法:1.列的别名 2.结果映射
1.列的别名
在SQL中使用 as 为查询字段添加列别名,以匹配属性名
public List<Role> findAll();
<select id="findAll" resultType="com.by.pojo.Role" >
select id, role_name as roleName, role_desc as roleDesc from role
</select>
但是如果我们的查询很多,都使用别名的话写起来就很麻烦
2.结果映射
使用
ResultMap
标签手动映射,解决实体字段和数据表字段不一致的问题
ResultMap
标签写一次之后,可以被多次使用,解决了需要写很多别名很麻烦的问题
public List<Role> findAll2();
<!--
id:和select查询标签的返回值保持一致
type: 映射实体的全类名
-->
<resultMap id="findAll2ResultMap" type="com.by.pojo.Role">
<!--
描述主键字段的映射关系:
property:实体类的属性
column:数据表字段名称
-->
<id property="id" column="id" />
<!--
描述非主键字段的映射关系:
property:实体类的属性
column:数据表字段名称
-->
<result property="roleName" column="role_name" />
<result property="roleDesc" column="role_desc" />
</resultMap>
<select id="findAll2" resultMap="findAll2ResultMap" >
select * from role
</select>