当前位置: 首页 > article >正文

Mybatis mapper文件 resultType和resultMap的区别

在 MyBatis 中,resultType 和 resultMap 都用于定义从数据库查询结果到 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>

在这个例子中,查询结果中的 idname 和 age 列将会直接映射到 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 将更加灵活和强大。选择合适的映射方式,有助于提高代码的可读性和维护性。


http://www.kler.cn/news/366035.html

相关文章:

  • UDP(用户数据报协议)端口监控
  • csa练习1
  • HivisionIDPhoto Docker部署以及Springboot接口对接(AI证件照制作)
  • vue计算属性报错:Computed property “energyTotal“ was assigned to but it has no setter.
  • HTTP和HTTPS基本概念,主要区别,应用场景
  • 如何将rust日志输出到android终端
  • 电脑重做系统后打游戏很卡
  • 循序渐进丨MogDB 与 PostgreSQL 对比测试IPv6
  • Flask-SocketIO 简单示例
  • unity游戏开发之塔防游戏
  • LinkAndroid v0.0.12 发布,手机连接助手,日志查看、投屏设置、多处问题修复
  • 光控资本:养老金融建设提速 高速铜缆市场空间广阔
  • 【工作技术栈】通用的旁路缓存一致性缺陷以及解决方式
  • ERR_PNPM_LINKING_FAILED Error: EPERM: operation not permitted, rename...
  • Scaffold-GS: Structured 3D Gaussians for View-Adaptive Rendering
  • 【python】OpenCV—findContours(4.2)
  • 【Go语言】
  • 简述特征降维的几种方式
  • IDEA中一个窗口打开多个项目-区别于eclipse
  • Netty-TCP服务端粘包、拆包问题(两种格式)
  • 使用Flask实现本机的模型部署
  • 【制造业&电子产品】电脑电子元件检测系统源码&数据集全套:改进yolo11-TADDH
  • 【贪心算法】(第十四篇)
  • 【前端学习路线】从入门到进阶(含学习资料链接和笔记)
  • 架构师备考专栏-导航页
  • ceph rgw使用sts Security Token Service