MyBatis 的映射关系

简介: MyBatis 核心功能之一是映射关系,支持一对一、一对多和多对多三种 ORM 映射。通过实体类与配置文件结合,开发者可灵活实现数据关联,提升数据库操作效率。

MyBatis 的映射关系是其核心功能之一,它允许开发者通过配置文件或注解的方式,将数据库表中的数据映射到 Java 对象中,实现对象关系映射(ORM)。MyBatis 主要支持一对一、一对多和多对多三种映射关系,以下是对这三种映射关系的详细介绍:

一、一对一映射
一对一映射是指一个对象与另一个对象具有严格的一对一关系。例如,一个用户(User)对应一个地址(Address)。在 MyBatis 中,可以通过以下步骤实现一对一映射:

创建实体类:为每个表创建对应的 Java 实体类,并在需要关联的实体类中定义关联属性。
配置映射文件:在映射文件中使用 标签来定义一对一映射关系。例如:
xml











编写查询方法:在 Mapper 接口中定义查询方法,并在映射文件中编写对应的 SQL 查询语句,使用上述定义的 resultMap 进行结果映射。
二、一对多映射
一对多映射是指一个对象与多个对象具有一对多的关系。例如,一个订单(Order)对应多个订单详情(OrderItem)。在 MyBatis 中,可以通过以下步骤实现一对多映射:

创建实体类:在订单实体类中定义一个集合属性来存储订单详情。
配置映射文件:在映射文件中使用 标签来定义一对多映射关系。例如:
xml











编写查询方法:在 Mapper 接口中定义查询方法,并在映射文件中编写对应的 SQL 查询语句,使用上述定义的 resultMap 进行结果映射。
三、多对多映射
多对多映射是指多个对象之间存在复杂的多对多关系。例如,学生(Student)和课程(Course)之间的关系。在数据库中,多对多关系通常需要通过一个中间表来实现。在 MyBatis 中,可以通过以下步骤实现多对多映射:

创建实体类:在学生和课程实体类中分别定义集合属性来存储对方对象。
配置映射文件:需要为中间表创建映射关系,并在学生和课程的映射文件中分别使用 标签来引用中间表的映射关系。
编写查询方法:在 Mapper 接口中定义查询方法,编写复杂的 SQL 查询语句(通常使用 JOIN 操作),并使用 resultMap 进行结果映射。

相关文章
|
XML Oracle Java
mybatis反向生成实体类、dao层以及映射文件
mybatis反向生成实体类、dao层以及映射文件
|
SQL Java 数据库连接
|
8月前
|
SQL XML Java
菜鸟之路Day35一一Mybatis之XML映射与动态SQL
本文介绍了MyBatis框架中XML映射与动态SQL的使用方法,作者通过实例详细解析了XML映射文件的配置规范,包括namespace、id和resultType的设置。文章还对比了注解与XML映射的优缺点,强调复杂SQL更适合XML方式。在动态SQL部分,重点讲解了`<if>`、`<where>`、`<set>`、`<foreach>`等标签的应用场景,如条件查询、动态更新和批量删除,并通过代码示例展示了其灵活性与实用性。最后,通过`<sql>`和`<include>`实现代码复用,优化维护效率。
752 5
|
10月前
|
SQL XML Java
七、MyBatis自定义映射resultMap
七、MyBatis自定义映射resultMap
290 6
|
10月前
|
Java 数据库连接 mybatis
MyBatis篇-映射关系(1-1 1-n n-n)
本文介绍了MyBatis中四种常见关系映射的配置方法,包括一对一、一对多、多对一和多对多。**一对一**通过`resultMap`实现属性与字段的映射;**一对多**以用户-角色为例,使用`<collection>`标签关联集合数据;**多对一**以作者-博客为例,利用`<association>`实现关联;**多对多**则通过引入第三方类(如UserForDept)分别在User和Dept类中添加集合属性,并配置对应的`<collection>`标签完成映射。这些方法解决了复杂数据关系的处理问题,提升了开发效率。
|
XML Java 数据库连接
Mybatis映射关系
简介:本文介绍了MyBatis框架中四种常见的关系映射方式,包括一对一、一对多、多对一及多对多。一对一通过简单属性映射实现;一对多通过在主对象中添加集合属性并使用`<collection>`标签映射子对象集合;多对一则利用`<association>`标签在主对象中映射单个子对象;多对多需引入第三方类,分别在两个主对象中添加对方的集合属性,并通过`<collection>`标签实现映射。
242 32
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
文章介绍了MyBatis中高级查询的一对多和多对一映射处理,包括创建数据库表、抽象对应的实体类、使用resultMap中的association和collection标签进行映射处理,以及如何实现级联查询和分步查询。此外,还补充了延迟加载的设置和用法。
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
|
SQL Java 数据库连接
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
567 3
|
Java 数据库连接 mybatis
mybatis映射关系(1-1 1-n n-n)
Mybatis 中的关系映射包括一对一、一对多和多对多。一对一映射可以通过ResultMap定义属性与字段的对应。一对多示例中,User类包含List<Role>,在User的mapper.xml中使用<collection>标签。多对一的情况,如Author与Blog,Blog的ResultMap中使用<association>来映射Author属性。多对多时,如部门与用户,通常需要中间表,并在双方实体中通过<collection>引用中间类,如UserForDept,来维护关系。