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

在这里插入图片描述

欢迎来到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.mzph.cn/news/639608.shtml

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

相关文章

司铭宇老师:房地产电话营销培训:房地产电话销售话术与销售技巧:打造高转化率的电话营销策略

房地产电话营销培训&#xff1a;房地产电话销售话术与销售技巧&#xff1a;打造高转化率的电话营销策略 在房地产销售中&#xff0c;电话销售是一种常见且有效的营销手段。它不仅可以快速触达潜在客户&#xff0c;还能够建立起销售人员与客户之间的初步信任关系。然而&#xff…

大模型学习之书生·浦语大模型6——基于OpenCompass大模型评测

基于OpenCompass大模型评测 关于评测的三个问题Why/What/How Why What 有许多任务评测&#xff0c;包括垂直领域 How 包含客观评测和主观评测&#xff0c;其中主观评测分人工和模型来评估。 提示词工程 主流评测框架 OpenCompass 能力框架 模型层能力层方法层工具层 支持丰富…

C++从小白到初级工程师【个人学习笔记】

目录 1.背景2.基础二维数组概念二维数组定义方式 二维数组数组名称概念例子 函数的分文件编写概念示例 指针指针的基本概念指针变量的定义和使用 空指针和野指针空指针实例野指针实例 const修饰指针概念const修饰指针 --- 常量指针 指针和数组作用示例 指针和函数作用示例 指针…

项目解决方案:某城区(区县)社会面视频监控资源接入汇聚解决方案

目 录 一、概述 二、建设目标及需求 1.建设目标 2.需求分析 2.1 总体需求 2.2 需求细化 三、方案设计 1.设计依据 2.设计原则 3.设计方案 3.1.方案描述 3.2.组网说明 四、产品介绍 1.视频监控综合资源管理平台介绍 2.视频录像服务器和存储 2.1…

python算法与数据结构(搜索算法和拓扑排序算法)---深度优先搜索

课程目标 了解树/图的深度遍历&#xff0c;宽度遍历基本原理&#xff1b;会使用python语言编写深度遍历&#xff0c;广度遍历代码&#xff1b;掌握拓扑排序算法 搜索算法的意义和作用 搜索引擎 提到搜索两个子&#xff0c;大家都应该会想到搜索引擎&#xff0c;搜索引擎的基…

网络安全(初版,以后会不断更新)

1.网络安全常识及术语 资产 任何对组织业务具有价值的信息资产&#xff0c;包括计算机硬件、通信设施、IT 环境、数据库、软件、文档 资料、信息服务和人员等。 漏洞 上边提到的“永恒之蓝”就是windows系统的漏洞 漏洞又被称为脆弱性或弱点&#xff08;Weakness&#xff09;&a…

DC-7靶机做题记录

靶机下载地址&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1w2c_QKd_hOoR2AzNrdZjMg?pwdtdky 提取码&#xff1a;tdky 参考&#xff1a; DC7靶机地址&#xff1a;http://www.five86.com/downloads/DC-7.zipDC7靶场介绍: https://www.vulnhub.com/entry/dc-7,356/…

AI+量化02_金融市场的基础概念

文章目录 问答之纯小白 vs GPT4Q1. 请用尽可能简短的语句或例子&#xff0c;给小白讲解宏观经济Q2. 给小白讲解资本边际效率Q3. 如果证券没有风险是否意味着没有收益&#xff1f;Q4. 芒格&#xff1a;教人炒股&#xff0c;犹如引人吸毒Q5. 给小白快速讲解&#xff1a;卡房统计量…

计算机速成课Crash Course - 21. 压缩

更多技术文章&#xff0c;全网首发公众号 “摸鱼IT” 锁定 -上午11点 - &#xff0c;感谢大家关注、转发、点赞&#xff01; 计算机速成课Crash Course - 21. 压缩 (qq.com) 今天继续计算机速成课Crash Course的系列讲解。 21. 压缩 上集我们讨论了文件格式&#xff0c;如何…

IN操作符

目录 IN NOT IN Oracle从入门到总裁:https://blog.csdn.net/weixin_67859959/article/details/135209645 IN IN 指的是根据一个指定的范围进行数据查询 1.查询出员工编号是 7369、7566、7788、9999 的员工信息 利用前面学的知识,得出: SQL> set linesize 250 SQL>…

Docker(十一)Swarm mode

作者主页&#xff1a; 正函数的个人主页 文章收录专栏&#xff1a; Docker 欢迎大家点赞 &#x1f44d; 收藏 ⭐ 加关注哦&#xff01; Swarm mode Docker 1.12 Swarm mode 已经内嵌入 Docker 引擎&#xff0c;成为了 docker 子命令 docker swarm。请注意与旧的 Docker Swarm …

力扣509. 斐波那契数

动态规划 思路&#xff1a; 斐波那契数通式&#xff1a;F(n) F(n - 1) F(n - 2)&#xff1b;以此为状态转移方程&#xff0c;对其进行动态规划&#xff1b;边界条件&#xff1a; F(0) 0F(1) 1使用两个变量来存储上一组结果&#xff1b; class Solution { public:int fib(…

Docker安装配置OnlyOffice

OnlyOffice 是一款强大的办公套件&#xff0c;你可以通过 Docker 轻松安装和部署它。本文将指导你完成安装过程。 步骤 1&#xff1a;拉取 OnlyOffice Docker 镜像 首先&#xff0c;使用以下命令从 Docker Hub 拉取 OnlyOffice Document Server 镜像&#xff1a; sudo docke…

计算机毕业设计 基于MVC的自习室管理和预约系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

如何用数据赋能社媒营销决策?

在数字化时代&#xff0c;越来越多的商家开始意识到数据分析对于改善经营的重要性。 传统决策更多依赖过往经验、商业直觉、他人的思路模板等方法&#xff0c;或者依靠描述性统计、简单的数据分析。在数字时代&#xff0c;则通过精细化数据分析&#xff0c;做出更明智的营销决策…

LLM包含的知识

基础知识 磨刀不误砍柴工&#xff0c;LLM基础知识还是需要的。会按照历史梳理LM&#xff0c;详解BERT、GPT系列等各种预备核心知识点&#xff0c;并带着进行GPT预训练实战、位置编码&#xff08;长文本问题&#xff09;实战等。 数据工程 数据很重要&#xff0c;数据是天花板…

在docker中配置 Linux ls 配色方案 与 shell 提示符

发行版中默认的配置一般非常合理&#xff0c;但是docker中往往忽略了这些简单的配置&#xff0c;备忘一下 1. ls 配色方案 vim &#xff5e;/.bashrc 在文件最末尾加入如下一行内容&#xff1a; export LS_COLORS"rs0:di01;34:ln01;36:mh00:pi40;33:so01;35:do01;35:bd40…

基于供水管网建模的漏损控制

1.1供水管网模型的概念和管网建模目的 供水管网系统是比较特殊的城市基础设施&#xff0c;不可见且属于压力管道。随着运行年限的增长&#xff0c;管道的过水能力和水泵的运行工况都发生了变化&#xff0c;管道的改扩建也使管网系统的结构发生了变化&#xff0c;导致系统运行状…

WPF-HelixToolkit包的使用(上)

1、引入HelixToolkit包&#xff1a;新建一个WPF项目&#xff0c;在项目“引用”上右击&#xff0c;选择“管理NutGet程序包”&#xff0c; 2、在左侧“浏览”中输入“helixtoolkit” 3、安装第一个“HelixToolkit”包 4、解决错误&#xff1a;右击属性->应用程序->目标框…

Unity -简单键鼠事件和虚拟轴

简单键鼠事件 — “Test_03” KeyTest 键鼠事件每帧都要监听&#xff0c;要放在Update()中处理 public class KeyTest : MonoBehaviour {// Start is called before the first frame updatevoid Start(){}// Update is called once per framevoid Update(){// 【鼠标点击事件…