【Spring 篇】MyBatis多表操作:编织数据的交响乐

news2025/1/11 22:47:57

在这里插入图片描述

欢迎来到MyBatis的多表操作世界!在这个充满交响乐的舞台上,我们将探索如何巧妙地编织多个数据表的数据,创造出一场旋律动听的数据交响曲。无需繁琐的SQL拼接,MyBatis让多表操作变得优雅而简单。让我们一起进入这个音乐殿堂,感受数据之间的和谐共振。

关联查询:数据之间的邂逅

在多表操作中,关联查询是我们的第一首交响曲。通过关联查询,我们能够从多个表中提取关联数据,让数据之间建立起一种柔和的连接。让我们通过一个实例来感受这种关联的美妙。

假设我们有两个表,一个是用户表(User),另一个是订单表(Order)。每个用户可以拥有多个订单,而每个订单都关联到一个用户。我们希望查询出某个用户的所有订单信息。在MyBatis中,我们可以使用@ResultMap注解和association元素完成这个查询:

public interface UserOrderMapper {

    @Results(id = "userOrderResult", value = {
            @Result(property = "id", column = "id"),
            @Result(property = "username", column = "username"),
            @Result(property = "orders", column = "id", javaType = List.class,
                    many = @Many(select = "com.example.mapper.UserOrderMapper.getOrdersByUserId"))
    })
    @Select("SELECT * FROM user WHERE id = #{id}")
    User getUserWithOrders(Long id);

    @Select("SELECT * FROM orders WHERE user_id = #{userId}")
    List<Order> getOrdersByUserId(Long userId);
}

在这个例子中,我们使用@Results注解定义了一个ResultMap,其中包含了用户和订单之间的关联关系。通过@Many元素,我们指定了关联的查询方法以及关联关系的字段。在getUserWithOrders方法中,我们通过@ResultMap注解引用了这个ResultMap,实现了用户和订单的关联查询。

嵌套查询:数据的层层深入

嵌套查询是多表操作中的另一项绝技,让我们能够在查询结果中包含更深层次的数据。假设我们需要查询用户信息以及每个用户最近的订单信息。通过嵌套查询,我们可以一次性获取到所有需要的信息,避免了多次查询的烦扰。

public interface UserOrderMapper {

    @Results(id = "userRecentOrderResult", value = {
            @Result(property = "id", column = "id"),
            @Result(property = "username", column = "username"),
            @Result(property = "recentOrder", column = "id", javaType = Order.class,
                    one = @One(select = "com.example.mapper.UserOrderMapper.getRecentOrderByUserId"))
    })
    @Select("SELECT * FROM user")
    List<User> getUsersWithRecentOrder();

    @Select("SELECT * FROM orders WHERE user_id = #{userId} ORDER BY create_time DESC LIMIT 1")
    Order getRecentOrderByUserId(Long userId);
}

在这个例子中,我们使用@Results注解定义了一个ResultMap,其中包含了用户和最近订单之间的嵌套查询关系。通过@One元素,我们指定了嵌套查询的查询方法以及嵌套关系的字段。在getUsersWithRecentOrder方法中,我们通过@ResultMap注解引用了这个ResultMap,实现了用户和最近订单的嵌套查询。

多表插入:数据的奏响

在多表操作中,插入数据同样是一项需要注意的技能。假设我们有用户表和订单表,我们希望同时插入一个新用户和与之关联的订单。MyBatis提供了@InsertProvider注解来支持动态SQL的插入操作:

public interface UserOrderMapper {

    @InsertProvider(type = UserOrderSqlProvider.class, method = "insertUserWithOrder")
    int insertUserWithOrder(User user, Order order);
}

在这个例子中,我们使用了@InsertProvider注解,并指定了Provider类的类型和方法。Provider类负责根据传入的参数生成动态SQL语句。在insertUserWithOrder方法中,我们同时插入了用户和订单的数据,实现了多表的插入操作。

多表更新和删除:数据的改编

更新和删除操作同样是多表操作中的常见需求。假设我们需要更新某个用户的信息以及与之关联的订单信息,或者删除某个用户及其关联的订单。通过MyBatis,我们可以很容易地实现这些操作:

public interface UserOrderMapper {

    @UpdateProvider(type = UserOrderSqlProvider.class, method = "updateUserWithOrder")
    int updateUserWithOrder(User user, Order order);

    @DeleteProvider(type = UserOrderSqlProvider.class, method = "deleteUserWithOrders")
    int deleteUserWithOrders(Long userId);
}

在这个例子中,我们使用了@UpdateProvider注解和@DeleteProvider注解,同样指定了Provider类的类型和方法。在Provider类中,我们可以根据传入的参数生成动态的更新和删除SQL语句。通过这样的方式,我们能够轻松实现多表的更新和删除操作。

小结:数据的和谐旋律

通过MyBatis多表操作,我们能够在数据的交响曲中编织出丰富的旋律。关联查询、嵌套查询、多表插入、多表更新和删除等技术,让我们能够灵活地应对不同的业务需求。希望通过这篇博客,你对MyBatis多表操作有了更深入的理解,能够在数据的大交响曲中演奏出和谐的旋律。在多表的音符中,让我们共同奏响数据的和谐乐章。

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1410654.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

全卷积网络:革新图像分析

一、介绍 全卷积网络&#xff08;FCN&#xff09;的出现标志着计算机视觉领域的一个重要里程碑&#xff0c;特别是在涉及图像分析的任务中。本文深入探讨了 FCN 的概念、它们的架构、它们与传统卷积神经网络 &#xff08;CNN&#xff09; 的区别以及它们在各个领域的应用。 就像…

DualSPHysics源码结构解读,新手入门

DualSPHysics代码下载&#xff0c;进入官网&#xff1a;https://dual.sphysics.org/ 可以看到下载的地方有①Full package ②Source code&#xff0c;官方的解读是&#xff1a;如果你只是想运行案例的话就下载Full package&#xff0c;如果想要自己进行修改构建的话&#xff0…

【modelsim使用】数据显示设置

本文介绍modelsim使用中数据的显示设置&#xff0c;定点小数的显示、模拟波形的显示、数据截位查看、信号颜色和行高设置的操作。 文章目录 定点小数显示模拟波形的显示选取信号的某几位组合查看信号颜色与行高设置 定点小数显示 使用modelsim进行仿真时&#xff0c;涉及到定点…

ICSpector:一款功能强大的微软开源工业PLC安全取证框架

关于ICSpector ICSpector是一款功能强大的开源工业PLC安全取证框架&#xff0c;该工具由微软的研究人员负责开发和维护&#xff0c;可以帮助广大研究人员轻松分析工业PLC元数据和项目文件。 ICSpector提供了方便的方式来扫描PLC并识别ICS环境中的可疑痕迹&#xff0c;可以用于…

PHP - Yii2 异步队列

1. 前言使用场景 在 PHP Yii2 中&#xff0c;队列是一种特殊的数据结构&#xff0c;用于处理和管理后台任务。队列允许我们将耗时的任务&#xff08;如发送电子邮件、push通知等&#xff09;放入队列中&#xff0c;然后在后台异步执行。这样可以避免在处理大量请求时阻塞主应用…

HTML-表格

表格 1.基本结构 一个完整的表格由&#xff1a;表格标题、表格头部、表格主体、表格脚注&#xff0c;四部分组成 表格涉及到的标签&#xff1a; table&#xff1a;表格 caption&#xff1a;标题 thead&#xff1a;表格头部 tbody&#xff1a;表格主体 tfoot&#xff1a;表格注…

精酿啤酒的原料供应链:质量控制的重要性

对于啤酒的品质和口感&#xff0c;原料供应链的质量控制是重要的。特别是对于Fendi Club这样品质的啤酒&#xff0c;其原料供应链的管理更是重中之重。下面&#xff0c;我们将深入探讨Fendi Club啤酒如何对其原料供应链进行质量控制&#xff0c;以确保啤酒的品质和口感。 首先&…

Matlab|含风电-光伏-光热电站电力系统N-k安全优化调度模型

目录 1 主要内容 程序算例 程序模型 程序亮点 2 部分程序 3 部分结果 4 下载链接 1 主要内容 该程序参考《光热电站促进风电消纳的电力系统优化调度》光热电站模型&#xff0c;主要做的是考虑N-k安全约束的含义风电-光伏-光热电站的电力系统优化调度模型&#xff0c;从而…

OllyDbg动态调试检测方案

据游戏工委数据统计&#xff0c;2023年国内客户端游戏市场实际销售收入达662.83亿元&#xff0c;同比增长8%。PC端游戏实际收入已连续4年实现增长&#xff0c;主要得益于现有的游戏收入持续增长以及更多新品在PC端同步发行等因素。 2023 PC端游戏市场实际销售收入 随着PC端游戏…

【JS】事件汇总(方便查找)

文章目录 一、鼠标事件二、键盘事件2.1、按下键盘键&#xff08;keydown&#xff09;2.2、抬起键盘键&#xff08;keyup&#xff09;2.3、按下有效键&#xff08;keypress&#xff09;2.4、常见键盘码&#xff08;了解&#xff09; 三、焦点事件3.1、聚焦&#xff08;focus&…

LC每日一题 2024/1/25 2859. 计算 K 置位下标对应元素的和

目录 题干 思路 代码 题干 思路 简单的位运算&#xff0c;就是寻找这个数对应的二进制中的1的个数是否与k相同&#xff0c;如果相同&#xff0c;就把这个数加到结果当中 可能涉及到的方法&#xff1a;Integer.bitCount() -->计算出二进制中包含的1的个数 代码 调用Java…

AI新工具(20240124) ComfyUI-InstantID-ComfyUI下的非官方InstantID实现;Lumiere是由谷歌时空扩散模型

ComfyUI-InstantID-ComfyUI下的非官方InstantID实现 ComfyUI InstantID是对InstantID的非官方实现&#xff0c;支持本地和huggingface hub模型&#xff0c;同时支持通用styler。它包括基础模型加载、InsightFace模型加载、ID ControlNet模型加载、Ipadapter_instantid模型加载…

银行数据仓库体系实践(6)--调度系统

调度系统是数据仓库的重要组成部分&#xff0c;也是每个银行或公司一个基础软件或服务&#xff0c;需要在全行或全公司层面进行规划&#xff0c;在全行层面统一调度工具和规范&#xff0c;由于数据类系统调度作业较多&#xff0c;交易类系统批量优先级高&#xff0c;为不互相影…

【算法分析与设计】二叉树的层序遍历

&#x1f4dd;个人主页&#xff1a;五敷有你 &#x1f525;系列专栏&#xff1a;算法分析与设计 ⛺️稳中求进&#xff0c;晒太阳 题目 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xf…

互联网泛人才流动报告:大厂扩张按下暂停键,这家公司逆势给出5w月薪招人

前段时间&#xff0c;脉脉高聘人才智库发布了《2023年互联网泛人才流动报告》&#xff0c;似乎佐证了23年是互联网真正的寒冬…… 卷生卷死&#xff01;5个人竞争2个岗位 2023年&#xff0c;互联网行业的求职难度可以说是地狱级别&#xff0c;人才供需比持续上升&#xff0c;…

【vue】Vue2和Vue3中的代码逻辑复用对比(mixins、自定义hook):

文章目录 一、前言&#xff1a;二、mixins&#xff1a;【1】mixins是什么&#xff1f;【2】mixins如何使用&#xff1f;【3】mixins的一些特性&#xff1a;【4】mixins的缺点&#xff1a; 三、hook&#xff1a;【1】Vue3.x中的自定义hook函数是什么&#xff1f;【2】mixins和Co…

log4j2配置文件命名及优先级

log4j 2.x版本不再支持像1.x中的.properties后缀的文件配置方式&#xff0c;2.x版本配置文件后缀名只能为".xml",“.json"或者”.jsn"。 命名规则 默认配置文件名&#xff1a; log4j2.xml 或 log4j2.json 测试或特定环境配置文件名&#xff1a;可以以 -t…

无人机航迹规划(七):五种元启发算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划(提供MATLAB代码)

一、五种算法&#xff08;DBO、LO、SWO、COA、GRO&#xff09;简介 1、蜣螂优化算法DBO 蜣螂优化算法&#xff08;Dung beetle optimizer&#xff0c;DBO&#xff09;由Jiankai Xue和Bo Shen于2022年提出&#xff0c;该算法主要受蜣螂的滚球、跳舞、觅食、偷窃和繁殖行为的启…

小程序样例3:根据日历创建待办事项

基本功能 1、待办事项查看 选择不同的日期显示不同的待办: 2、选择日期后 新增事项&#xff1a; 3. 点击事项&#xff0c;查看详情 4、删除事项&#xff1a;删除事项3之后&#xff0c;剩余事项2 5、点击日期可以选择更多的月&#xff1a; 实现思路&#xff1a; 1、数据结构&a…

.zip 文件和 .tar.gz文件 的区别

tgz和zip两种压缩格式,其实这两个压缩文件里面包含的内容是一样的,只是压缩格式不一样. tar.gz格式的文件比zip文件要小不少。tar.gz压缩格式用于unix的操作系统, 而zip用于windows的操作系统,但在windows系统中WinRar工具同样可以解压缩tar.gz格式的。 扩展&#xff1a; z…