其他分享
首页 > 其他分享> > 5、MyBatis初级教程之ResultMap

5、MyBatis初级教程之ResultMap

作者:互联网

6、ResultMap

要解决的问题:属性名和字段名不一致

1、查看之前的数据库的字段名

img

2、Java中的实体类设计

public class User {

   private int id;  //id
   private String name;   //姓名
   private String password;   //密码和数据库不一样!
   
   //构造
   //set/get
   //toString()
}

3、接口

//根据id查询用户
User getUserByIdMap(int id);

4、mapper映射文件

<select id="getUserByIdMap" resultType="user">
  select * from user where id = #{id}
</select>

5、测试

@Test
public void testgetUserByIdMap() {
   SqlSession session = MybatisUtils.getSession();  //获取SqlSession连接
   UserMapper mapper = session.getMapper(UserMapper.class);
   User user = mapper.getUserByIdMap(1);
   System.out.println(user);
   session.close();
}

结果:

分析:

解决方案

方案一:为列名指定别名 , 别名和java实体类的属性名一致 .

<select id="getUserByIdMap" resultType="User">
  select id , name , pwd as password from user where id = #{id}
</select>

方案二:使用结果集映射->ResultMap 【推荐】

<resultMap id="UserMap" type="User">
   <!-- id为主键 -->
   <id column="id" property="id"/>
   <!-- column是数据库表的列名 , property是对应实体类的属性名 -->
   <result column="name" property="name"/>
   <result column="pwd" property="password"/>
</resultMap>

<select id="getUserByIdMap" resultMap="UserMap">
  select id , name , pwd from user where id = #{id}
</select>

ResultMap

自动映射

你已经见过简单映射语句的示例了,但并没有显式指定 resultMap。比如:

<select id="getUserByIdMap" resultType="map">
select id , name , pwd
  from user
  where id = #{id}
</select>

上述语句只是简单地将所有的列映射到 HashMap 的键上,这由 resultType 属性指定。虽然在大部分情况下都够用,但是 HashMap 不是一个很好的模型。你的程序更可能会使用 JavaBean 或 POJO(Plain Old Java Objects,普通老式 Java 对象)作为模型。

ResultMap 最优秀的地方在于,虽然你已经对它相当了解了,但是根本就不需要显式地用到他们。

手动映射

1、返回值类型为resultMap

<select id="getUserByIdMap" resultMap="UserMap">
  select id , name , pwd from user where id = #{id}
</select>

2、编写resultMap,实现手动映射!

<resultMap id="UserMap" type="User">
   <!-- id为主键 -->
   <id column="id" property="id"/>
   <!-- column是数据库表的列名 , property是对应实体类的属性名 -->
   <result column="name" property="name"/>
   <result column="pwd" property="password"/>
</resultMap>

如果世界总是这么简单就好了。但是肯定不是的,数据库中,存在一对多,多对一的情况,我们之后会使用到一些高级的结果集映射,association,collection这些,我们将在之后讲解,今天你们需要把这些知识都消化掉才是最重要的!理解结果集映射的这个概念!

标签:name,映射,ResultMap,初级教程,user,MyBatis,where,id,select
来源: https://www.cnblogs.com/chenn/p/13345361.html