第八章 Mybatis及MybatisPlus

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 本文介绍了MyBatis系统架构流程、结果集映射、Mapper传参、XML常用配置、缓存机制及分页插件等内容,涵盖SqlSessionFactory构建、Executor执行器、一级与二级缓存原理,并对比PageHelper与MyBatis Plus分页使用方式,同时介绍MyBatis Plus常用API,助力高效开发。

1、系统架构流程

执行过程:

  1. mybatis配置

mybatis-config.xml,名称可变,此文件作为mybatis的全局配置文件,配置了mybatis的运行环境等信息。mapper.xml文件即sql映射文件,文件中配置了操作数据库的sql语句。此文件需要在mybatis-config.xml中加载;

  1. 通过mybatis环境等配置信息构造SqlSessionFactory即会话工厂;
  2. 由会话工厂创建sqlSession即会话,操作数据库需要通过sqlSession进行;
  3. mybatis底层自定义了Executor执行器接口操作数据库,Executor接口有两个实现,一个是基本执行器、一个是缓存执行器;
  4. Mapped Statement也是mybatis一个底层封装对象,它包装了mybatis配置信息及sql映射信息等。mapper.xml文件中一个sql对应一个Mapped Statement对象,sql的id即是Mapped statement的id;
  5. Mapped Statement对sql执行输入参数进行定义,包括HashMap、基本类型、pojo,Executor通过 Mapped Statement在执行sql前将输入的java对象映射至sql中,输入参数映射就是jdbc编程中对preparedStatement设置参数;
  6. Mapped Statement对sql执行输出结果进行定义,包括HashMap、基本类型、pojo,Executor通过 Mapped Statement在执行sql后将输出结果映射至java对象中,输出结果映射过程相当于jdbc编程中对结果的解析处理过程。

2、结果集映射

在 MyBatis 中,结果集映射是指将查询数据库得到的结果集映射到 Java 对象的过程。MyBatis 提供了 XML 配置和注解两种方式来进行结果集映射。

1)使用xml的方式;则可以使用 resultTyperesultMap ;其中 resultType可以直接指定类名即可。而 resultMap可以映射更加复杂的映射关系;包括 一对一(可以使用 association )、一对多(可以使用 collection )等复杂的关联关系。

2)使用注解的方式;可以使用 @Select@Result 配合使用。

3、mapper传参

在 MyBatis 中,Mapper 接口中定义的方法可以接受参数来进行数据库操作。Mapper 方法可以接受多种类型的参数,包括基本数据类型、Java 对象、Map 等。

1、在mapper接口中的方法形参前面使用 @Param 指定名称;然后在映射文件或者@Select 注解内直接使用 #{} 或者 ${} 获取;

2、不使用 @Param ;那么直接在需要使用的sql语句中,参数的名称要写成 param1,param2。。。

3、如果传递的是一个对象或者map类型;那么在sql也可以直接使用对象或map的属性或key名称

4、xml常用配置

MyBatis 的 XML 配置文件中包含了许多常用的配置项,这些配置项可以帮助你定义映射关系、SQL 查询、参数传递等。以下是一些 MyBatis XML 配置中常用的配置:

1)数据源配置:配置连接数据库的信息,包括驱动类、URL、用户名和密码等。

2)映射器配置:指定映射器文件或映射器接口的位置。

3)类型别名配置:为 Java 类型指定别名,简化映射器文件中的使用。

4)结果映射配置:定义 SQL 查询结果与 Java 对象之间的映射关系。

5)SQL 查询配置:编写 SQL 查询语句,并指定参数类型、返回结果类型等。

6)参数传递配置:定义方法参数传递方式,可以使用基本类型、Java 对象、Map 等作为参数。

5、缓存机制

MyBatis 提供了两级缓存(Local Cache 和 Second Level Cache)来满足不同的需求。

1、Local Cache(本地缓存、一级缓存)

  • Local Cache 是指在 SqlSession 范围内的缓存,它默认开启并且无法关闭。
  • 在同一个 SqlSession 中,当执行相同的查询语句(包括参数相同)时,如果之前已经查询过相同的结果,那么会直接从本地缓存中获取数据,而不会再发送 SQL 查询到数据库。
  • Local Cache 是基于 HashMap 实现的,它仅在当前 SqlSession 中有效,并且对于不同的 SqlSession 是隔离的。

2、Second Level Cache(二级缓存)

  • Second Level Cache 是指在 Mapper 范围内的缓存,它可以跨 SqlSession 共享数据。
  • 如果开发者需要使用 Second Level Cache,需要在映射文件中进行配置。
  • 当开启了 Second Level Cache 后,同一个 namespace 下的查询结果会被缓存起来,其他 SqlSession 也可以共享这部分数据,从而减少数据库查询次数。
  • Second Level Cache 默认是关闭的,需要手动在映射文件中配置开启。

6、分页插件

MyBatis 中常见的分页插件有: PageHelperMyBatis Plus 都是用于简化分页查询操作的工具,它们能够大大简化分页查询的代码编写,并提供了丰富的分页功能。两类插件都是基于Mybatis的拦截器实现;所以需要在使用之前添加对应的拦截器。而在使用的时候:

  • PageHelper中使用的参考: `
PageHelper.startPage(页号, 页大小);
  • MybatisPlus中的使用参考:
IPage<User> userPage = userService.page(new Page<>(页号, 页大小));

7、Mybatis-Plus常用API

MyBatis Plus 是在 MyBatis 的基础上进行增强的工具,提供了丰富的 API 来简化数据访问层的开发。常见的api有如下图:

相关文章
|
2月前
|
缓存 NoSQL Java
[ERP]SpringBoot集成Redis技术(☆)
本文介绍如何克隆并运行ERP项目代码,通过Git或ZIP方式获取源码,配置JDK、Maven等环境,解决常见问题,并强调主动请教同事的重要性。要求使用Redis优化商品查询接口,考虑缓存三剑客及增删改时的缓存更新,推荐用Postman等工具测试接口。
 [ERP]SpringBoot集成Redis技术(☆)
|
2月前
|
存储 Java Nacos
第九章 SpringCloud框架
本文系统介绍了微服务架构中的核心技术组件,涵盖Nacos与Eureka的服务注册与发现机制、OpenFeign的远程调用流程、Sentinel与Hystrix的限流熔断对比、滑动窗口算法原理,以及Spring Cloud Gateway的路由断言、过滤器功能与实现方式,全面解析微服务间通信、配置管理与流量治理方案。
|
2月前
|
存储 安全 网络协议
第三章 web阶段
HTTP协议是超文本传输协议,基于TCP实现,规定了客户端与服务器间的数据通信规则。常见请求方式有GET和POST,前者用于获取数据,后者用于提交数据。HTTPS在HTTP基础上通过SSL加密提升安全性。常见状态码如200(成功)、404(未找到)、500(服务器错误)等。转发是服务器内部跳转,重定向则由浏览器发起新请求。Cookie和Session用于会话跟踪,前者存于客户端,后者依赖服务器存储,底层仍借助Cookie传递ID。
|
2月前
|
人工智能 Java easyexcel
[Blog]SpringBootExcel导入(☆☆☆)
本任务要求实现博客系统的Excel导入功能,掌握SpringBoot、MySQL、Maven及EasyExcel/POI技术。预计AI辅助1小时,手动4小时。需自主分析需求,结合教程或AI完成,培养独立开发能力。
|
2月前
|
人工智能 Java 关系型数据库
[舍弃,后续需调整][Blog]JPA实现分页需求(☆☆)
本任务要求在博客系统中实现分页查询功能,需掌握SpringBoot、MySQL、Maven及JPA基础知识。建议使用AI辅助开发,预计耗时1-4小时。需自行添加测试数据以展示分页效果,可基于现有工程改造,注重实践而非标准答案。
 [舍弃,后续需调整][Blog]JPA实现分页需求(☆☆)
|
2月前
|
Java 网络安全 开发工具
[MES]不合格订单接入提醒功能(☆☆☆)
本文介绍如何克隆并运行指定Git项目,涉及JDK、Maven等环境配置问题的应对策略,强调新人如何高效请教同事。项目需求为:当不合格工单超30分钟时触发通知(短信或钉钉),需结合定时任务实现,并分析新增与修改场景。核心技术栈为Git、Maven、SpringBoot。
 [MES]不合格订单接入提醒功能(☆☆☆)
|
2月前
|
Java easyexcel 开发工具
[MES]分页与Excel批量上传(☆☆)
本文介绍如何克隆并运行一个SpringBoot项目,涉及Git、Maven等工具配置,强调新人如何解决环境搭建、需求不明确等问题,并实现分页与批量上传功能,提升实战能力。
|
2月前
|
Java Maven 数据库
02-Activiti工程搭建
本教程介绍如何在Idea中创建Maven工程并安装ActiBPM插件,包含插件下载、版本兼容性修复、手动修改JAR配置及验证安装等步骤,同时引入Activiti相关依赖,完成Spring Boot项目集成流程引擎的初步搭建。
02-Activiti工程搭建
|
2月前
|
前端开发 Java 关系型数据库
[Blog]三层架构:代码本地运行(☆)
本任务要求掌握SpringBoot、MySQL、Maven基础,用时约2小时。需将项目本地运行,解决JDK、Maven等环境问题,并修复因数据库未导入、名称不一致导致的查看博客异常。完成后访问http://localhost:8080测试。
|
2月前
|
Java 关系型数据库 网络安全
低代码平台RuoYi:代码本地运行(☆☆)
简介:本任务要求新入职员工掌握SpringCloud、MySQL、Maven等技术栈,通过SSH方式拉取若依(RuoYi)项目代码并本地运行。需观看文档、解决常见Git权限问题,录制不少于8分钟的视频,结构化输出对项目技术栈、核心功能、数据库关系的理解,并提出困惑,助力快速融入团队开发。
低代码平台RuoYi:代码本地运行(☆☆)