mybatis配置文件之resultMap和resultType

本文详细解析Mybatis中的resultMap和resultType配置,重点探讨它们的区别与应用场景。resultMap允许自定义映射规则,能处理复杂的关联映射,而resultType则简单直接,适用于基本类型的映射。通过实例分析,帮助读者掌握如何灵活运用这两种映射方式来优化数据处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

****不废话,直接上代码
pojo:****

package com.meetManager.entity;

import java.util.Date;

public class CarRepairSer{
 private String carNum;
 private String mark;
 private Date time;
 private String billNum;//报案号
 public String getCarNum() {
  return carNum;
 }
 public void setCarNum(String carNum) {
  this.carNum = carNum;
 }
 public String getMark() {
  return mark;
 }
 public void setMark(String mark) {
  this.mark = mark;
 }
 public Date getTime() {
  return time;
 }
 public void setTime(Date time) {
  this.time = time;
 }
 public String getBillNum() {
  return billNum;
 }
 public void setBillNum(String billNum) {
  this.billNum = billNum;
 }
}


dao层代码

@Autowired
 protected SqlSessionTemplate sqlSession;

public List<CarRepairSer>getRepairList(){
  return sqlSession.selectList("carRepair.select_repair_list");
 }

下面上xml代码

两种写法

下面用的是resultType

<select id="select_repair_list" parameterType="String" resultType="com.meetManager.entity.CarRepairSer">
     SELECT car_num carNum,mark,time,bill_num billNum
     from car_repair_ser 
 </select>

注意,因为表中字段是car_num  而实体类中是carNum  为了获得值,可以采用字段别名的方式

如果字段和实体类一样,那么不必用别的方式

对应的service层代码是

List<CarRepairSer> list = carRepairDao.getRepairList();




下面用的是resultMap
<mapper namespace="carRepair">
 <resultMap type="java.util.HashMap" id="repairSer">
        <result column="car_num" javaType="java.lang.String" property="carNum"/>
        <result column="mark" javaType="java.lang.String" property="mark"/>
        <result column="time" javaType="java.lang.String" property="time"/>
        <result column="bill_num" javaType="java.lang.String" property="billNum"/>
 </resultMap>
 <select id="select_repair_list" parameterType="String" resultMap="repairSer">
     SELECT car_num carNum,mark,time,bill_num billNum
     from car_repair_ser 
 </select>
</mapper>

对应service层的代码时

List list=carRepairDao.getRepairList();

当然这个list装的是hashmap类型的

不知道大家可否看明白了 ,不明白的留言,看到之后会给予解答。

<think>好的,我现在需要详细解释MyBatisresultMapresultType的区别及使用场景。根据用户提供的引用资料,我需要综合这些信息,并确保回答结构清晰,符合用户的要求。 首先,用户引用了四个来源,说明他们希望得到详细的对比,包括对象映射的方式、灵活性、配置复杂度以及适用场景。我需要先整理每个引用的重点: 引用1提到resultMapresultType的区别在于对象不同、描述不同、类型适用不同。resultMap更强大,适用于复杂映射,而resultType需要列名属性名一致。 引用2补充说resultMap可以自定义映射,即使字段名属性名不一致也能处理,而resultType必须严格一致,比如cIdc_id都不行。 引用3通过示例说明,当使用resultType时,如果数据库字段属性名不同,可以在SQL中使用别名来匹配。例如user_Id AS userId。 引用4指出resultMap在处理一对一时,可以在主表的pojo中嵌套另一个表的pojo,并使用association节点处理关联。 接下来,我需要将以上信息组织成清晰的对比项,并给出使用场景。可能需要分点说明区别,比如功能对比、配置方式、灵活性等。然后,分别列出各自的适用场景,比如简单映射用resultType,复杂关联用resultMap。 需要确保回答中使用正确的中文,并且数学表达式或代码示例符合要求的格式。用户的问题中没有涉及数学公式,但需要检查是否有类似情况,比如如果有变量可能需要用$...$,但这里可能不需要。 另外,用户要求生成相关问题,需要根据内容提出三个相关问题,比如性能、优化方法、应用场景等。但这里需要围绕resultMapresultType的区别来生成问题,例如自动映射的问题、配置方法、关联查询处理等。 最后,确保引用的标注正确,每个引用对应的内容要自然标注在末尾。例如引用[^1]、[^2]等,根据用户提供的引用顺序,可能需要对应到正确的来源。 现在,将这些整理成一个结构化的回答,分为区别总结使用场景,每个部分分点说明,并添加相关问题。同时,检查是否有遗漏的信息,比如resultMap支持一对一、一对多关联,而resultType不支持这些,这也是引用4提到的内容。</think>### MyBatis 中 `resultMap` 与 `resultType` 的区别及使用场景 #### 1. **核心区别** - **`resultType`** - **直接映射简单对象**:要求查询结果的列名与 Java 对象的属性名**完全一致**,否则无法自动映射。 - **灵活性低**:若数据库字段与属性名不一致(如 `c_id` vs `cId`),需在 SQL 中使用别名显式匹配,例如: ```sql SELECT user_id AS userId, user_name AS userName FROM users ``` 否则会导致映射失败[^3][^2]。 - **适用场景**:单表查询、字段与属性名严格对齐的简单映射。 - **`resultMap`** - **自定义映射规则**:可手动定义字段与属性的对应关系,**无需依赖列名一致性**。 - **支持复杂关联**:通过 `<association>`(一对一) `<collection>`(一对多)处理嵌套对象,例如将关联表的查询结果映射到主表对象的属性中[^4]。 - **灵活性高**:适合多表连接、字段名与属性名差异较大的场景[^2]。 #### 2. **配置复杂度对比** - **`resultType`**:无需额外配置,仅需指定 Java 类路径(如 `resultType="com.xxx.User"`)。 - **`resultMap`**:需在 XML 中定义 `<resultMap>` 节点,明确字段与属性的映射关系,例如: ```xml <resultMap id="userMap" type="com.xxx.User"> <id property="userId" column="user_id"/> <result property="userName" column="user_name"/> <association property="role" resultMap="roleMap"/> </resultMap> ``` #### 3. **性能与适用场景** - **`resultType` 适用场景**: - 单表查询且字段名与属性名一致。 - 对性能要求较高,需减少 XML 配置复杂度。 - **`resultMap` 适用场景**: - 多表关联查询(如嵌套对象、集合属性)。 - 字段名与属性名不一致或存在特殊转换逻辑(如日期格式化)。 - 需要复用映射规则时,可定义全局 `resultMap`[^2][^4]。 #### 4. **总结** || `resultType` | `resultMap` | |---|---|---| | **映射方式** | 自动(依赖列名) | 手动(自定义规则) | | **复杂度** | 低 | 高 | | **灵活性** | 有限 | 高 | | **适用场景** | 简单单表查询 | 复杂关联查询 | ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值