resultMap结果集映射解决属性名和字段不一致问题
解决属性名和字段名不一致的问题
1.出现的问题
数据库中的字段
新建一个项目,拷贝之前的,测试实体类与数据库字段不一致的情况
public class User {
private int id;
private String name;
private String password;
}
现在测试出现问题
解决方法:
方法一:最简单的在sql语句中直接起别名
<select id="getUserById" resultType="user">
select id,name,pwd as password from mybatis.user where id = #{id}
</select>
方法二就是使用下面的resultMap
2、resultMap
结果集映射
首先定义一个resultMap的标签做数据库字段与实体类属性的映射(注:可以只映射不相同的字段与属性)
<!--resultMap叫结果集映射,
就是实现将sql查询出来的结果集映射到实体类里-->
<resultMap id="UserMap" type="User">
<!--column数据库的字段,property实体类中的属性-->
<!--resultMap可以什么哪个字段不一样转哪个字段,
并不用数据库列和实体类属性全部写完-->
<!-- <result column="id" property="id"/>
<result column="name" property="name"/>-->
<result column="pwd" property="password"/>
</resultMap>
然后select标签取引用它,如下:
<select id="getUserById" resultMap="UserMap">
select * from mybatis.user where id = #{id}
</select>
这就是结果集映射的用法。
下面时截取的Mybatis官网上的一些针对resultMap的重要信息:
-
resultMap
元素是 MyBatis 中最重要最强大的元素。 - ResultMap 的设计思想是,对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了。
- 相同的字段和属性名不用做映射也可。
- 如果这个世界总是这么简单就好了。(哈哈哈哈)