Mybatis mapper文件 resultType和resultMap的区别

在 MyBatis 中,resultTyperesultMap 都用于定义从数据库查询结果到 Java 对象的映射规则,但它们之间存在着一些关键的区别。以下是对这两者的详细说明和区别:

1. resultType

定义

**resultType**是 MyBatis 查询语句中的一个属性,用于指定查询结果的 Java 类型。它告诉 MyBatis 应该将查询的结果映射为哪种类的对象。

用法
  • 适用于简单的对象映射,尤其是当查询返回的列名直接与 Java 对象的属性相符合时。
  • 可以直接使用基本数据类型或类名。
示例
复制代码
<select id="getStudentById" resultType="com.example.Student">
    SELECT id, name, age FROM students WHERE id = #{id}
</select>

在这个例子中,查询结果中的 idnameage 列将会直接映射到 Student 类的对应属性上。

2. resultMap

定义

resultMap 是 MyBatis 的一个更灵活和复杂的映射机制,用于定义更具体的映射规则,包括列名与属性之间的自定义映射、嵌套结果映射等。

用法
  • 当查询结果的列名与 Java 对象的属性名不完全匹配,或者有更复杂的映射关系时,使用 resultMap 更为合适。
  • 支持多种类型的映射,包括一对多、多对一和嵌套映射。
示例
复制代码
<resultMap id="studentResultMap" type="com.example.Student">
    <result property="id" column="id"/>
    <result property="name" column="name"/>
    <result property="age" column="age"/>
</resultMap>

<select id="getStudentById" resultMap="studentResultMap">
    SELECT id, name, age FROM students WHERE id = #{id}
</select>

在这个例子中,resultMap 明确地定义了 Student 对象的每个属性与 SQL 查询中每个列名之间的对应关系。

总结

在选择使用 resultType 还是 resultMap 时,应该根据业务需求和查询的复杂性进行选择。如果映射关系简单且列名与属性名相同,使用 resultType 更加方便;若需要自定义映射关系或处理复杂的对象结构,使用 resultMap 将更加灵活和强大。选择合适的映射方式,有助于提高代码的可读性和维护性。

相关推荐
考虑考虑1 天前
Jpa使用union all
java·spring boot·后端
用户3721574261351 天前
Java 实现 Excel 与 TXT 文本高效互转
java
浮游本尊1 天前
Java学习第22天 - 云原生与容器化
java
渣哥1 天前
原来 Java 里线程安全集合有这么多种
java
间彧1 天前
Spring Boot集成Spring Security完整指南
java
间彧1 天前
Spring Secutiy基本原理及工作流程
java
Java水解1 天前
JAVA经典面试题附答案(持续更新版)
java·后端·面试
洛小豆1 天前
在Java中,Integer.parseInt和Integer.valueOf有什么区别
java·后端·面试
前端小张同学1 天前
服务器上如何搭建jenkins 服务CI/CD😎😎
java·后端
ytadpole1 天前
Spring Cloud Gateway:一次不规范 URL 引发的路由转发404问题排查
java·后端