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>