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

20. 如何在MyBatis中处理多表关联查询?常见的实现方式有哪些?

在MyBatis中处理多表关联查询是一项常见的需求,特别是在关系型数据库中存储复杂的实体关系时。MyBatis提供了多种方式来实现多表关联查询,常见的实现方式包括使用<association><collection>标签在<resultMap>中进行对象关系映射,以及通过嵌套查询和手动SQL语句来实现。

1. 使用 和 标签进行一对一关联查询

<association> 标签用于处理一对一关联关系(通常是主表和从表之间的一对一映射)。通过<association>标签,可以将从表的数据加载到主表的对应对象属性中。

1.1 示例:查询用户及其对应的地址信息(User与Address的一对一关系)

  • 数据库表

    • users表:存储用户信息,包含idusernameaddress_id等字段。

    • address表:存储地址信息,包含idstreetcity等字段。

  • MyBatis映射配置

    <resultMap id="userResultMap" type="User"><id property="id" column="id" /><result property="username" column="username" /><association property="address" javaType="Address" column="address_id" select="selectAddressById" />
    </resultMap>
    ​
    <select id="findUserById" resultMap="userResultMap">SELECT * FROM users WHERE id = #{id}
    </select>
    ​
    <select id="selectAddressById" resultType="Address">SELECT * FROM address WHERE id = #{id}
    </select>
  • 解释

    • <association>:定义了一对一的关联关系,其中propertyUser对象的属性名,javaType是关联对象的类型,column是外键,select用于指定查询关联对象的SQL。

    • 当查询用户时,MyBatis会首先执行findUserById查询users表,然后根据address_id执行selectAddressById查询address表,并将结果映射到User对象的address属性中。

2. 使用 和 标签进行一对多关联查询

<collection> 标签用于处理一对多或多对多关联关系(如一个用户有多个订单的关系)。通过<collection>标签,可以将从表的多行数据映射为主表对象的一个集合属性。

2.1 示例:查询用户及其对应的订单信息(User与Orders的一对多关系)

  • 数据库表

    • users表:存储用户信息,包含idusername等字段。

    • orders表:存储订单信息,包含iduser_idorder_date等字段。

  • MyBatis映射配置

    <resultMap id="userResultMap" type="User"><id property="id" column="id" /><result property="username" column="username" /><collection property="orders" ofType="Order" column="id" select="selectOrdersByUserId" />
    </resultMap>
    ​
    <select id="findUserById" resultMap="userResultMap">SELECT * FROM users WHERE id = #{id}
    </select>
    ​
    <select id="selectOrdersByUserId" resultType="Order">SELECT * FROM orders WHERE user_id = #{id}
    </select>
  • 解释

    • <collection>:定义了一对多的关联关系,propertyUser对象的集合属性名,ofType是集合中元素的类型,column是关联键,select用于指定查询从表数据的SQL。

    • 当查询用户时,MyBatis会先执行findUserById查询users表,然后根据id执行selectOrdersByUserId查询orders表,并将结果映射为User对象的orders集合属性。

3. 通过嵌套查询实现多表关联

MyBatis支持通过在<resultMap>或SQL语句中嵌套查询的方式来实现多表关联。

3.1 示例:查询用户及其订单(嵌套查询实现)

  • 嵌套查询

    <select id="findUserWithOrders" resultMap="userWithOrdersResultMap">SELECT u.id AS user_id, u.username, o.id AS order_id, o.order_dateFROM users uLEFT JOIN orders o ON u.id = o.user_idWHERE u.id = #{id}
    </select>
    ​
    <resultMap id="userWithOrdersResultMap" type="User"><id property="id" column="user_id"/><result property="username" column="username"/><collection property="orders" ofType="Order"><id property="id" column="order_id"/><result property="orderDate" column="order_date"/></collection>
    </resultMap>
  • 解释

    • 在这个例子中,<collection>标签在<resultMap>中定义了orders集合,MyBatis会根据查询结果的多个行自动组装成User对象的orders集合。

    • SQL语句通过LEFT JOIN直接关联了usersorders表,返回的结果集通过<resultMap>映射到对象属性。

4. 使用手动SQL拼接

在某些复杂的场景下,开发者可能希望完全控制SQL语句的生成,这时可以手动编写多表关联查询的SQL。

4.1 示例:手动SQL拼接

<select id="findUserWithOrders">SELECT u.id AS user_id, u.username, o.id AS order_id, o.order_dateFROM users uLEFT JOIN orders o ON u.id = o.user_idWHERE u.id = #{id}
</select>
  • 解释:

    • 手动SQL拼接方式适合更复杂的查询场景,可以完全利用SQL的能力来处理多表关联查询。这种方式下,MyBatis只负责执行SQL并将结果映射为对象,开发者需要确保SQL的正确性和优化。

5. 使用自定义映射器

在一些复杂的查询场景中,可能需要通过自定义映射器(即在Java代码中手动处理结果集)来实现多表关联查询。

5.1 示例:使用自定义映射器

public List<User> findUserWithOrders() {List<User> users = userMapper.findUsers();for (User user : users) {List<Order> orders = userMapper.findOrdersByUserId(user.getId());user.setOrders(orders);}return users;
}
  • 解释:

    • 这种方式完全在Java代码中控制多表关联的查询和映射,适合处理非常复杂的业务逻辑或需要进行额外的数据处理的场景。

总结

在MyBatis中处理多表关联查询的常见实现方式有以下几种:

  1. <association> 标签:处理一对一关联关系,将从表的数据映射到主表对象的一个属性。

  2. <collection> 标签:处理一对多或多对多关联关系,将从表的多行数据映射为主表对象的一个集合属性。

  3. 嵌套查询:通过嵌套查询实现复杂的关联关系查询,将结果映射到对象属性中。

  4. 手动SQL拼接:直接手写SQL,通过JOIN等操作进行多表关联查询,并映射结果。

  5. 自定义映射器:在Java代码中手动处理结果集,适合非常复杂的业务逻辑场景。

选择哪种方式应根据具体的需求和查询复杂度来决定,合理使用这些方式可以有效地处理数据库的多表关联查询,提高系统的性能和可维护性。

相关文章:

20. 如何在MyBatis中处理多表关联查询?常见的实现方式有哪些?

在MyBatis中处理多表关联查询是一项常见的需求&#xff0c;特别是在关系型数据库中存储复杂的实体关系时。MyBatis提供了多种方式来实现多表关联查询&#xff0c;常见的实现方式包括使用<association>和<collection>标签在<resultMap>中进行对象关系映射&…...

【百日算法计划】:每日一题,见证成长(013)

题目 回文链表 给你一个单链表的头节点 head &#xff0c;请你判断该链表是否为回文链表。如果是&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 输入&#xff1a;head [1,2,2,1] 输出&#xff1a;true 思路 找到中间节点反转后半部分链表前后链表顺序比…...

PCL 读取和保存点云

目录 一、概述 1.1原理 1.2实现步骤 二、代码实现 2.1关键函数 2.2完整代码 三、实现效果 PCL点云算法汇总及实战案例汇总的目录地址链接&#xff1a; PCL点云算法与项目实战案例汇总&#xff08;长期更新&#xff09; 一、概述 1.1原理 PCL (Point Cloud Library) 是…...

js | TypeError: Cannot read properties of null (reading ‘indexOf’) 【解决】

js | TypeError: Cannot read properties of null (reading ‘indexOf’) 【解决】 描述 概述 在前端开发中&#xff0c;遇到TypeError: Cannot read properties of null (reading indexOf)这类错误并不罕见。这个错误通常表明你试图在一个null值上调用indexOf方法&#xff0c…...

微信小程序-formData使用

作者&#xff1a;fyupeng 技术专栏&#xff1a;☞ https://github.com/fyupeng 项目地址&#xff1a;☞ https://github.com/fyupeng/distributed-blog-system-api 留给读者 一、介绍 在小程序中使用formdata上传数据&#xff0c;可实现多文件上传 跟浏览器中的FormData对象类…...

潜在语义分析(Latent Semantic Analysis,LSA)—无监督学习方法、非概率模型、判别模型、线性模型、非参数化模型、批量学习

定义 输入: X [ x 11 x 12 ⋯ x 1 n x 21 x 22 ⋯ x 2 n ⋮ ⋮ ⋮ ⋮ x m 1 x m 2 ⋯ x m n ] , 文本集合 D { d 1 , d 2 , ⋯ , d n } , 单词集合 W { ω 1 , ω 2 , ⋯ , ω m } , x i j : 单词 ω i 在文本 d j 中出现的频数或权值 X\left[ \begin{array}{cccc} x_{11} …...

【安全漏洞】MySQL 8.0.33 、CVE-2023-22102

mysql-connector-java:jar:8.0.33已经重新定位到mysql-connector-j:jar:8.0.33 安全漏洞描述 在SBOM扫描过程中&#xff0c;检测到mysql-connector-j:8.0.33存在如下高危安全漏洞&#xff1a; CVE-2023-22102&#xff1a;Oracle MySQL Connectors 8.1.0 版本之前存在安全漏洞&…...

Flutter 响应式框架

一、简介 响应式框架会自动使用户界面适应不同的屏幕大小。创建你的用户界面一次&#xff0c;让它显示完美的像素在移动&#xff0c;平板电脑和桌面&#xff01; 1.1 问题 支持多种显示尺寸通常意味着要多次重新创建同一布局。在传统的Bootstrap方法下&#xff0c;构建响应式…...

电脑AE特效软件 After Effects软件2017中文版下载安装指南 (Win/Mac)

电脑ae特效软件 After Effects软件2017中文版下载安装win/... 电脑AE特效软件 After Effects软件2017中文版下载安装指南 (Win/Mac) Adobe After Effects 2017 是一款功能强大的视频后期处理软件&#xff0c;广泛应用于影视特效制作、动态图形设计、视觉效果合成等领域。其丰…...

C#中的装箱和拆箱是什么

在 C# 中&#xff0c;装箱&#xff08;Boxing&#xff09;和拆箱&#xff08;Unboxing&#xff09;是与值类型和引用类型相关的概念&#xff0c;涉及到值类型的数据在托管堆&#xff08;Heap&#xff09;上的存储方式。 装箱&#xff08;Boxing&#xff09; 装箱是指将值类型…...

在 Debian 12 上安装中文五笔输入法

在 Debian 12 上安装中文五笔输入法&#xff0c;你可以通过以下步骤进行&#xff1a; 更新系统包列表&#xff1a; 打开终端&#xff0c;首先更新你的系统包列表&#xff1a; sudo apt update安装输入法框架&#xff1a; 安装 fcitx5 输入法框架&#xff1a; sudo apt install …...

整流器制造5G智能工厂物联数字孪生平台,推进制造业数字化转型

整流器制造行业作为制造业的重要组成部分&#xff0c;也在积极探索数字化转型的新路径。整流器&#xff0c;作为电力电子领域的关键元件&#xff0c;广泛应用于通信、工业控制、新能源等多个领域&#xff0c;其制造过程的智能化升级不仅关乎产品性能的提升&#xff0c;更是推动…...

算法知识点——常用输入输出数据的方式

如果输入的每组数据的结果不相互干扰的话&#xff0c;就可以在本次操作的时候将该组数据的相关结果进行输出。 1、n组输入输出(n确定&#xff09; scanf("%d",&n); while(n--) {scanf("%d %d",&a,&b); printf("%d %d\n",a,b);}cin…...

如何构建大数据治理平台,助力企业数据决策

建设背景 &#xff08;1&#xff09;什么是数据资产 资产由企业及组织拥有和控制&#xff0c;能够提供增值服务、带来经济利益的重要资源。 资产不但需要管理&#xff0c; 更需要运营。 &#xff08;2&#xff09;数据资产运营中的问题 数据资产运营中存在的问题主要包括以下…...

Playwright与Selenium的对比:谁是更适合你的自动化测试工具?

在自动化测试领域&#xff0c;Selenium 一直是行业的标杆工具。它功能强大、支持多浏览器、广泛应用于各类项目中。然而&#xff0c;随着技术的发展&#xff0c;新的工具不断涌现&#xff0c;Playwright 作为其中的佼佼者&#xff0c;以其现代化的设计和强大的特性吸引了越来越…...

Netty 相关问题

传统网络编程存在的问题 传统网络编程存在以下问题&#xff1a; 线程创建开销&#xff1a;在Java中&#xff0c;创建线程需要调用操作系统API&#xff0c;这会消耗资源和时间。内存占用高&#xff1a;线程本身占用内存&#xff0c;创建过多线程会导致内存资源紧张。CPU使用率…...

JAVA中线程池的详解

1.概念 顾名思义&#xff0c;线程池就是管理一系列线程的资源池&#xff0c;其提供了一种限制和管理线程资源的方式。每个线程池还维护一些基本统计信息&#xff0c;例如已完成任务的数量。 这里借用《Java 并发编程的艺术》书中的部分内容来总结一下使用线程池的好处&#x…...

【PyTorch单点知识】深入了解 nn.ModuleList和 nn.ParameterList模块:灵活构建动态网络结构

文章目录 0. 前言1. 为什么需要 nn.ModuleList 和 nn.ParameterList&#xff1f;2. nn.ModuleList&#xff1a;管理模块的列表2.1 什么是 nn.ModuleList&#xff1f;2.2 创建 nn.ModuleList2.3 动态添加或删除层 3. nn.ParameterList&#xff1a;管理参数列表3.1 什么是 nn.Par…...

vscode创建Python虚拟环境无法激活问题处理

系统环境 win7环境,Python3.7,VScode1.70.3 问题报错: PS C:\Users\Administrator\PycharmProjects\websites> .\venv\Scripts\activate 无法加载文件 C:\Users\Administrator\PycharmProjects\websites\venv\Scripts\Activate.ps1,因为在此系统中禁止执行脚本。有关…...

【Go】Go语言中的基本数据类型与类型转换

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…...

Cursor实现用excel数据填充word模版的方法

cursor主页&#xff1a;https://www.cursor.com/ 任务目标&#xff1a;把excel格式的数据里的单元格&#xff0c;按照某一个固定模版填充到word中 文章目录 注意事项逐步生成程序1. 确定格式2. 调试程序 注意事项 直接给一个excel文件和最终呈现的word文件的示例&#xff0c;…...

树莓派超全系列教程文档--(62)使用rpicam-app通过网络流式传输视频

使用rpicam-app通过网络流式传输视频 使用 rpicam-app 通过网络流式传输视频UDPTCPRTSPlibavGStreamerRTPlibcamerasrc GStreamer 元素 文章来源&#xff1a; http://raspberry.dns8844.cn/documentation 原文网址 使用 rpicam-app 通过网络流式传输视频 本节介绍来自 rpica…...

从WWDC看苹果产品发展的规律

WWDC 是苹果公司一年一度面向全球开发者的盛会&#xff0c;其主题演讲展现了苹果在产品设计、技术路线、用户体验和生态系统构建上的核心理念与演进脉络。我们借助 ChatGPT Deep Research 工具&#xff0c;对过去十年 WWDC 主题演讲内容进行了系统化分析&#xff0c;形成了这份…...

江苏艾立泰跨国资源接力:废料变黄金的绿色供应链革命

在华东塑料包装行业面临限塑令深度调整的背景下&#xff0c;江苏艾立泰以一场跨国资源接力的创新实践&#xff0c;重新定义了绿色供应链的边界。 跨国回收网络&#xff1a;废料变黄金的全球棋局 艾立泰在欧洲、东南亚建立再生塑料回收点&#xff0c;将海外废弃包装箱通过标准…...

linux 错误码总结

1,错误码的概念与作用 在Linux系统中,错误码是系统调用或库函数在执行失败时返回的特定数值,用于指示具体的错误类型。这些错误码通过全局变量errno来存储和传递,errno由操作系统维护,保存最近一次发生的错误信息。值得注意的是,errno的值在每次系统调用或函数调用失败时…...

今日科技热点速览

&#x1f525; 今日科技热点速览 &#x1f3ae; 任天堂Switch 2 正式发售 任天堂新一代游戏主机 Switch 2 今日正式上线发售&#xff0c;主打更强图形性能与沉浸式体验&#xff0c;支持多模态交互&#xff0c;受到全球玩家热捧 。 &#x1f916; 人工智能持续突破 DeepSeek-R1&…...

【JVM】Java虚拟机(二)——垃圾回收

目录 一、如何判断对象可以回收 &#xff08;一&#xff09;引用计数法 &#xff08;二&#xff09;可达性分析算法 二、垃圾回收算法 &#xff08;一&#xff09;标记清除 &#xff08;二&#xff09;标记整理 &#xff08;三&#xff09;复制 &#xff08;四&#xff…...

LRU 缓存机制详解与实现(Java版) + 力扣解决

&#x1f4cc; LRU 缓存机制详解与实现&#xff08;Java版&#xff09; 一、&#x1f4d6; 问题背景 在日常开发中&#xff0c;我们经常会使用 缓存&#xff08;Cache&#xff09; 来提升性能。但由于内存有限&#xff0c;缓存不可能无限增长&#xff0c;于是需要策略决定&am…...

Caliper 配置文件解析:fisco-bcos.json

config.yaml 文件 config.yaml 是 Caliper 的主配置文件,通常包含以下内容: test:name: fisco-bcos-test # 测试名称description: Performance test of FISCO-BCOS # 测试描述workers:type: local # 工作进程类型number: 5 # 工作进程数量monitor:type: - docker- pro…...

Chromium 136 编译指南 Windows篇:depot_tools 配置与源码获取(二)

引言 工欲善其事&#xff0c;必先利其器。在完成了 Visual Studio 2022 和 Windows SDK 的安装后&#xff0c;我们即将接触到 Chromium 开发生态中最核心的工具——depot_tools。这个由 Google 精心打造的工具集&#xff0c;就像是连接开发者与 Chromium 庞大代码库的智能桥梁…...