MyBatis之ResultMap的Association和Collection标签详解

一、前言

MyBatis 创建时的一个思想是:数据库不可能永远是你所想或所需的那个样子。我们希望每个数据库都具备良好的第三范式或 BCNF 范式,可惜它们并不都是那样。如果能有一种数据库映射模式,完美适配所有的应用程序,那就太好了,但可惜也没有。而 ResultMap 就是 MyBatis 对这个问题的答案。

二、ResultMap 的属性列表

属性

描述

id

当前命名空间中的一个唯一标识,用于标识一个结果映射。

type

类的完全限定名, 或者一个类型别名(关于内置的类型别名,可以参考上面的表格)。

autoMapping

如果设置这个属性,MyBatis 将会为本结果映射开启或者关闭自动映射。这个属性会覆盖全局的属性 autoMappingBehavior。默认值:未设置(unset)。

extends

可以继承其他resultMap的一些写好的属性

三、resultMap标签介绍

  • constructor – 用于在实例化类时,注入结果到构造方法中。
  • idArg – ID 参数;标记出作为 ID 的结果可以帮助提高整体性能。
  • arg – 将被注入到构造方法的一个普通结果。
  • id – 一个 ID 结果;标记出作为 ID 的结果可以帮助提高整体性能。
  • result – 注入到字段或 JavaBean 属性的普通结果。
  • association – 一个复杂类型的关联;许多结果将包装成这种类型。
    嵌套结果映射 – 关联可以是 resultMap 元素,或是对其它结果映射的引用。
  • collection – 一个复杂类型的集合。
    嵌套结果映射 – 集合可以是 resultMap 元素,或是对其它结果映射的引用。
  • discriminator – 使用结果值来决定使用哪个 resultMap。
  • case – 基于某些值的结果映射。
    嵌套结果映射 – case 也是一个结果映射,因此具有相同的结构和元素;或者引用其它的结果映射。

四、id & result标签参数详解

属性

描述

property

映射到列结果的字段或属性。如果 JavaBean 有这个名字的属性(property),会先使用该属性。否则 MyBatis 将会寻找给定名称的字段(field)。无论是哪一种情形,你都可以使用常见的点式分隔形式进行复杂属性导航。人话为:就是你的Java实体类

column

数据库中的列名,或者是列的别名。一般情况下,这和传递给 resultSet.getString(columnName) 方法的参数一样。

javaType

一个 Java 类的全限定名,或一个类型别名(关于内置的类型别名,可以参考上面的表格)。如果你映射到一个 JavaBean,MyBatis 通常可以推断类型。然而,如果你映射到的是 HashMap,那么你应该明确地指定 javaType 来保证行为与期望的相一致。

jdbcType

JDBC 类型,所支持的 JDBC 类型参见这个表格之后的“支持的 JDBC 类型”。只需要在可能执行插入、更新和删除的且允许空值的列上指定 JDBC 类型。这是 JDBC 的要求而非 MyBatis 的要求。如果你直接面向 JDBC 编程,你需要对可以为空值的列指定这个类型。

typeHandler

我们在前面讨论过默认的类型处理器。使用这个属性,你可以覆盖默认的类型处理器。这个属性值是一个类型处理器实现类的全限定名,或者是类型别名。

常用例子展示

<resultMap >五、association标签常用参数详解

属性

描述

property

映射到列结果的字段或属性。如果用来匹配的 JavaBean 存在给定名字的属性,那么它将会被使用。否则 MyBatis 将会寻找给定名称的字段。无论是哪一种情形,你都可以使用通常的点式分隔形式进行复杂属性导航。人话为:你要一对一的实体类中的另一个实体类的名称

javaType

一个 Java 类的完全限定名,或一个类型别名。 如果你映射到一个 JavaBean,MyBatis 通常可以推断类型。然而,如果你映射到的是 HashMap,那么你应该明确地指定 javaType 来保证行为与期望的相一致。

例子演示

  • 实体类演示
@Data
//书籍
publicclassBook {
privateStringid;
privateStringname;
privateStringauthor;
privateDoubleprice;
privateIntegerdel;
privateDatepublishdate;
privateStringinfo;
//把出版社对象当作属性
privatePublisherpub;//------重点在这里一本书对应一个出版社,这是一个出版社对象
}
@Data
//出版社
publicclassPublisher {
privateStringid;
privateStringname;
privateStringphone;
privateStringaddress;
}

xml演示

<resultMapid="rMap_book"type="com.wang.test.demo.entity.Book">
<!--主键property为实体类属性column为数据库字段jdbcType为实体类对应的jdbc类型-->
<idproperty="id"column="b_id"jdbcType="VARCHAR"></id>
<!--普通属性property为实体类属性column为数据库字段jdbcType为实体类对应的jdbc类型-->
<resultproperty="name"column="b_name"jdbcType="VARCHAR"></result>
<resultproperty="author"column="author"jdbcType="VARCHAR"></result>
<resultproperty="price"column="price"jdbcType="VARCHAR"></result>
<resultproperty="del"column="del"jdbcType="NUMERIC"></result>
<resultproperty="publisherid"column="publisher_id"jdbcType="VARCHAR"></result>
<resultproperty="publishdate"column="publish_date"jdbcType="TIMESTAMP"></result>
<!--一对一映射associationproperty为实体类book中的属性名字javaType为实体类属性的类型-->
<associationproperty="pub"javaType="com.wang.test.demo.entity.Publisher">
<idproperty="id"column="p_id"jdbcType="VARCHAR"></id>
<resultproperty="name"column="name"jdbcType="VARCHAR"></result>
<resultproperty="phone"column="phone"jdbcType="VARCHAR"></result>
<resultproperty="address"column="address"jdbcType="VARCHAR"></result>
</association>
</resultMap>

六、collection标签常用参数详解

属性

描述

property

映射到列结果的字段或属性。如果用来匹配的 JavaBean 存在给定名字的属性,那么它将会被使用。否则 MyBatis 将会寻找给定名称的字段。无论是哪一种情形,你都可以使用通常的点式分隔形式进行复杂属性导航。人话为:你要一对一的实体类中的另一个实体类的名称

javaType

这里和一对一的表示不太一样,这里一般是一对多的集合类型,如:list

ofType

指定的这个一对多的集合的所存放的实体类的类型

例子演示

实体类演示

@Data
//班级类
public class Class {

private String id;
private String name;
private List<Student> students;//----重点在这里,一个班级对应多个学生

}
@Data
public class Student {

private int id;
private String name;
private int age;
}

 xml演示

<resultMap>七、jdbc Type与java Type对照表

JDBC Type

Java Type

CHAR

String

VARCHAR

String

LONGVARCHAR

String

NUMERIC

java.math.BigDecimal

DECIMAL

java.math.BigDecimal

BIT

boolean

BOOLEAN

boolean

TINYINT

byte

SMALLINT

short

INTEGER

INTEGER

BIGINT

long

REAL

float

FLOAT

double

DOUBLE

double

BINARY

byte[]

VARBINARY

byte[]

LONGVARBINARY

byte[]

DATE

java.sql.Date

TIME

java.sql.Time

TIMESTAMP

java.sql.Timestamp

CLOB

Clob

BLOB

Blob

ARRAY

Array

DISTINCT

mapping of underlying type

STRUCT

Struct

REF

Ref

DATALINK

java.net.URL

八、总结

这样就对ResultMap具体参数进行详细的解释,还有对association和collection标签的解释和具体演示,希望能够帮到你。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/271216.html<

(0)
运维的头像运维
上一篇2025-05-08 04:33
下一篇 2025-05-08 04:34

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注