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 将更加灵活和强大。选择合适的映射方式,有助于提高代码的可读性和维护性。

相关推荐
代码村新手10 分钟前
C++-类和对象(中)
java·开发语言·c++
葵花楹27 分钟前
【JAVA课设】【游戏社交系统】
java·开发语言·游戏
kylezhao201930 分钟前
C# 文件的输入与输出(I/O)详解
java·算法·c#
千层冷面35 分钟前
数据库分库分表
java·数据库·mysql·oracle
赵谨言38 分钟前
Python串口的三相交流电机控制系统研究
大数据·开发语言·经验分享·python
民乐团扒谱机1 小时前
【微实验】数模美赛备赛:多目标优化求解实战(MATLAB实现,以流水车间调度为例)
开发语言·数学建模·matlab·甘特图·遗传算法·多目标优化·优化模型
努力的小陈^O^1 小时前
问题:Spring循环依赖问题排查与解决
java·开发语言·前端
Ccjf酷儿1 小时前
C++语言程序设计 (郑莉)第十章 泛型程序设计与C++标准模板库
开发语言·c++
HehuaTang2 小时前
requests 调大并对齐 limits 提升POD高负载场景下性能
java·docker·kubernetes
FreeBuf_2 小时前
利用零宽度字符的隐形JavaScript混淆工具InvisibleJS浮出水面
开发语言·javascript·ecmascript