MyBatis的resultType和resultMap区别

resultType和resultMap是在使用 MyBatis 框架时,映射查询结果到对象时使用的两个不同的配置元素。它们的主要区别在于它们如何映射 SQL 查询的结果集到 Java 对象。

1. resultType

  • resultType是一个简单的类型别名或者是一个完全限定的类名。

  • 它用于将查询结果直接映射到一个简单的 Java 对象或者一个 Map 对象。

  • 当使用resultType时,MyBatis会默认按照列名和对象属性名进行映射,如果列名和属性名不一致,需要手动指定映射关系。

  • 适用于简单场景,当结果集直接对应于一个 Java 对象时。

示例:

XML 复制代码
<select id="selectUser" resultType="com.example.User">
     SELECT id, username, password FROM users WHERE id = #{id}
   </select>

2. resultMap

  • resultMap提供了一个更高级的、细粒度的控制,允许定义复杂的映射策略。
  • 它允许为每个列指定一个映射路径,包括嵌套属性和集合属性。
  • resultMap可以用于处理关联查询,将多个表的结果映射到一个对象或者对象的集合中。
  • 它提供了更复杂的映射功能,如集合、继承、嵌套结果等。

示例:

XML 复制代码
<resultMap id="userResultMap" type="com.example.User">
     <id property="id" column="id" />
     <result property="username" column="username" />
     <result property="password" column="password" />
</resultMap>
   <select id="selectUser" resultMap="userResultMap">
     SELECT id, username, password FROM users WHERE id = #{id}
   </select>

总的来说,resultType适用于简单的映射,而 resultMap提供了更复杂的映射能力,适用于需要精细控制结果集映射的场景。

相关推荐
Mr_pyx19 小时前
面试题记录
jvm·数据结构·算法·spring·mybatis
摇滚侠1 天前
Mybatis 面试题 真正的 offer 偏方 Java 基础 Java 高级
java·开发语言·mybatis
Devin~Y1 天前
大厂Java面试实录:Spring Boot/Cloud + Redis + Kafka + JVM + RAG(Spring AI)三轮追问(小Y翻车版)
java·jvm·spring boot·redis·spring cloud·kafka·mybatis
月落归舟1 天前
一篇文章了解Redis内存淘汰机制与过期Key清理
数据库·redis·mybatis
Devin~Y2 天前
大厂Java面试实录:Spring Boot/WebFlux、JVM调优、Redis/Kafka、Spring Cloud 与 RAG/Agent 追问
java·jvm·spring boot·maven·mybatis·jpa·spring webflux
Boop_wu2 天前
[Java项目] Spring Boot + WebSocket 实现网页在线聊天室|完整项目架构与实战讲解
spring boot·websocket·java-ee·mybatis
IronMurphy3 天前
Redis拷打第三讲
数据库·redis·mybatis
小坏讲微服务3 天前
SpringBoot4.0整合Spring Security+MyBatis Plus完整权限框架实现
java·spring·mybatis·spring security·mybatis plus·springboot4.0
静小谢3 天前
sql笔记
spring boot·笔记·sql·mybatis
桔筐3 天前
MyBatis-Plus Service/ServiceImpl/IService 核心关系
mybatis