MyBatis的基本概念和核心组件
MyBatis的基本概念
MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录
MyBatis的特点
- 简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件。易于学习,易于使用。通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
- 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
- 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
- 提供映射标签,支持对象与数据库的ORM字段关系映射。
- 提供对象关系映射标签,支持对象关系组建维护。
- 提供xml标签,支持编写动态sql
MyBatis架构
我们把MyBatis架构分为三层
- API接口层的主要作用
- 定义接口方法:API接口层主要用于定义与数据库交互的方法。通常,每个接口方法对应一条SQL语句或一组相关的SQL语句,用于执行查询、插入、更新或删除等数据库操作
- 参数传递:API接口层可以定义方法的输入参数,用于传递查询条件、更新数据等操作所需的参数。MyBatis提供了各种方式来传递参数,包括基本类型、对象、Map等。
- 结果映射:API接口层可以定义方法的返回类型,用于接收数据库操作的结果。MyBatis支持将查询结果映射为Java对象或集合,并提供了丰富的结果映射规则和配置方式。
- SQL语句映射:API接口层可以通过注解或XML配置的方式,将SQL语句与接口方法进行映射。这样,在调用接口方法时,MyBatis会自动执行对应的SQL语句,并将结果返回给调用方。
- 事务支持:API接口层可以通过注解或XML配置的方式,添加事务的支持。这样,在接口方法执行期间,可以保证数据库操作的原子性,保证数据的一致性和完整性。
- 数据处理层的主要作用
- 定义映射关系:数据处理层使用映射文件或注解来定义数据库表与Java实体对象的映射关系。这些映射关系包括表名、字段名、主键、关联关系等。通过定义映射关系,MyBatis可以将查询结果自动映射为Java对象。
- 编写SQL语句:数据处理层使用SQL语句来执行数据库的增删改查操作。SQL语句可以使用MyBatis提供的映射文件或注解来定义,也可以使用动态SQL来实现灵活的条件查询。SQL语句可以包括普通的SQL语句、参数占位符、动态条件等。
- 执行数据库操作:数据处理层使用Mapper接口来执行数据库操作。Mapper接口定义了与数据库操作相关的方法,例如插入数据、更新数据、删除数据、查询数据等。通过调用Mapper接口的方法,可以执行对应的SQL语句并返回结果
- 事务管理:数据处理层可以通过注解或配置文件来管理事务。在需要保证多个数据库操作的原子性时,可以使用事务管理来确保数据的一致性和完整性。MyBatis提供了多种方式来配置和管理事务,例如使用注解、使用AOP、使用XML配置等。
- 基础支撑层的主要作用
- 数据源管理:基础支撑层负责管理应用程序连接数据库的数据源。它可以配置和管理连接池,提供数据库连接的分配和释放,以及数据库事务的管理等。
- SQL语句执行:基础支撑层提供了执行SQL语句的能力。它负责将SQL语句和参数传递给数据库,并获取执行结果。它还负责处理SQL语句的预编译、占位符替换、结果集的映射等操作。
- 对象-关系映射:基础支撑层负责将数据库中的记录映射为Java对象。它可以根据配置或注解,自动将查询结果集映射为Java对象,并提供对象与数据库记录之间的转换功能。
- 缓存管理:基础支撑层提供了缓存机制,用于提高数据库访问性能。它可以缓存查询结果,避免重复访问数据库,提高响应速度。MyBatis提供了不同级别的缓存配置,包括一级缓存和二级缓存。
- 异常处理:基础支撑层处理数据库操作过程中可能出现的各种异常,如数据库连接异常、SQL语句执行异常、事务回滚等。它负责将异常转换为可读的错误信息,并提供异常处理机制。
MyBatis核心组件
- SqlSessionFactory:SqlSessionFactory是MyBatis的核心接口之一,它负责创建SqlSession对象。SqlSession是与数据库交互的主要入口,通过SqlSessionFactory可以获取SqlSession实例,然后进行数据库操作。
- SqlSession:SqlSession是MyBatis与数据库交互的关键组件,它提供了执行SQL语句、获取映射器(Mapper)、管理事务等功能。通过SqlSession,可以执行数据库的增删改查操作,并获取操作结果。
- SqlSession:SqlSession是MyBatis与数据库交互的关键组件,它提供了执行SQL语句、获取映射器(Mapper)、管理事务等功能。通过SqlSession,可以执行数据库的增删改查操作,并获取操作结果。
- 映射器(Mapper):映射器是MyBatis实现动态代理的核心组件。MyBatis通过JDK动态代理或CGLIB动态代理,根据定义的Mapper接口,动态生成代理类,实现接口方法的具体逻辑。通过映射器,可以将Java对象与数据库记录进行映射,实现对象关系映射。
- Configuration配置对象:Configuration对象是MyBatis的配置文件解析和存储的核心组件。它负责解析MyBatis的配置文件,包括数据库连接信息、映射文件路径、插件、类型处理器等配置信息。MyBatis根据Configuration对象的配置,完成MyBatis的初始化和功能扩展。
- Executor执行器:Executor执行器是MyBatis执行SQL语句的核心组件。它负责根据SQL语句、参数和映射规则,将SQL语句发送到数据库,并获取结果。Executor可以分为SimpleExecutor、ReuseExecutor和BatchExecutor等类型,用于不同的场景和需求。
相关文章:
MyBatis的基本概念和核心组件
MyBatis的基本概念 MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Pla…...
sql update执行返回0,能否判断数据不存在
答案:不能。 update执行返回0的情况 1、没有找到需要更新的数据,就是这条记录不存在 例如:where后面的条件是id0,那这条记录肯定是不存在的,返回结果是0 2、更新时的数据和要更新的数据完全一致时 例如:更…...

数据分析 | 调用Optuna库实现基于TPE的贝叶斯优化 | 以随机森林回归为例
1. Optuna库的优势 对比bayes_opt和hyperoptOptuna不仅可以衔接到PyTorch等深度学习框架上,还可以与sklearn-optimize结合使用,这也是我最喜欢的地方,Optuna因此特性可以被使用于各种各样的优化场景。 2. 导入必要的库及加载数据 用的是sklea…...

stm32单片机开关输入控制蜂鸣器参考代码(附PROTEUS电路图)
说明:这个buzzer的额定电压需要改为3V,否则不会叫,源代码几乎是完全一样的 //gpio.c文件 /* USER CODE BEGIN Header */ /********************************************************************************* file gpio.c* brief Thi…...

打印X型的图案
int main() {int n0;int i0;int j0;scanf("%d",&n);for(i0;i<n;i){for(j0;j<n;j){if(ij){printf("*");}else if((ij)n-1){printf("*");}elseprintf(" ");}printf("\n");}return 0; }...

不含数字的webshell绕过
异或操作原理 1.首先我们得了解一下异或操作的原理 在php中,异或操作是两个二进制数相同时,异或(相同)为0,不同为1 举个例子 A的ASCII值是65,对应的二进制值是0100 0001 的ASCII值是96,对应的二进制值是 0110 000…...

Mac上传项目源代码到GitHub的修改更新
Mac上传项目源代码到GitHub的修改更新 最近在学习把代码上传到github,不得不说,真的还挺方便 这是一个关于怎样更新项目代码的教程。 首先,在本地终端命令行打开至项目文件下第一步:查看当前的git仓库状态,可以使用git…...

Android6:片段和导航
创建项目Secret Message strings.xml <resources><string name"app_name">Secret Message</string><string name"welcome_text">Welcome to the Secret Message app!Use this app to encrypt a secret message.Click on the Star…...

ClickHouse AST is too big 报错问题处理记录
ClickHouse AST is too big 报错问题处理记录 问题描述问题分析解决方案1、修改系统配置2、修改业务逻辑 问题描述 项目中统计报表的查询出现 AST is too big 问题,报错信息如下: 问题分析 报错信息显示 AST is too big。 AST 表示查询语法树中的最大…...

DPDK系列之二十七DIDO
一、DIDO介绍 随着计算机技术发展,特别是应用技术的快速发展。应用场景对计算机的处理速度几乎已经到了疯狂的地步。说句大白话,再快的CPU也嫌慢。没办法,CPU和IO等技术基本目前都处在了瓶颈之处,大幅度提高,短时间内…...

《游戏编程模式》学习笔记(七)状态模式 State Pattern
状态模式的定义 允许对象在当内部状态改变时改变其行为,就好像此对象改变了自己的类一样。 举个例子 在书的示例里要求你写一个人物控制器,实现跳跃功能 直觉上来说,我们代码会这么写: void Heroine::handleInput(Input input…...

博客系统之功能测试
博客系统共有:用户登录功能、发布博客功能、查看文章详情功能、查看文章列表功能、删除文章功能、退出功能 1.登录功能: 1.1测试对象:用户登录 1.2测试用例 方法:判定表 用例 编号 操作步骤预期结果实际结果截图1 1.用户名正确…...
CJS和 ES6 的语法区别
CommonJS 使用 module.exports 导出模块。ES6 使用 export 导出模块。 示例代码: CommonJS(CJS)模块的导出: // 导出模块 module.exports {foo: bar,baz: function() {return qux;} }; ES6 模块的导出: // 导出模…...

ArcGIS Pro如何制作不规则形状图例
在默认的情况下,ArcGIS Pro生成的图例是标准的点、直线和矩形的,对于湖泊等要素而言,这样的表示方式不够直观,我们可以将其优化一下,制作不规则的线和面来代替原有图例,这里为大家介绍一下制作方法…...

微软Win11 Dev预览版Build23526发布
近日,微软Win11 Dev预览版Build23526发布,修复了不少问题。牛比如斯Microsoft,也有这么多bug,所以你写再多bug也不作为奇啊。 主要更新问题 [开始菜单] 修复了在高对比度主题下,打开开始菜单中的“所有应…...

【NEW】视频云存储EasyCVR平台H.265转码配置增加分辨率设置
关于视频分析EasyCVR视频汇聚平台的转码功能,我们在此前的文章中也介绍过不少,感兴趣的用户可以翻阅往期的文章进行了解。 安防视频集中存储EasyCVR视频监控综合管理平台可以根据不同的场景需求,让平台在内网、专网、VPN、广域网、互联网等各…...

【数据结构】如何用队列实现栈?图文详解(LeetCode)
LeetCode链接:225. 用队列实现栈 - 力扣(LeetCode) 本文默认读者已经掌握栈与队列的基本知识 或者先看我的另一篇博客:【数据结构】栈与队列_字节连结的博客-CSDN博客 做题思路 由于我们使用的是C语言,不能直接使用队…...

Linux 虚拟机Ubuntu22.04版本通过远程连接连接不上,输入ifconfig只能看到127.0.0.1的解决办法
之前给虚拟机配置静态IP之后,可以直接通过主机Vscode远程连接。但是前一段时间把主机的TCP/IPV4静态IP设置了一下之后,再连接虚拟机就连不上了,于是参考解决虚拟机不能上网ifconfig只显示127.0.0.1的问题,又可以连接上了ÿ…...

C语言刷题训练DAY.9
1.线段图案 解题思路: 这里非常简单,我们只需要用一个循环控制打印即可。 解题代码: #include<stdio.h> int main() {int n 0;while ((scanf("%d", &n)) ! EOF){int i 0;for (i 0; i < n; i){printf("*&…...

CTFHub php://input
1.首先看代码: 这里其实就应该想到的是php://伪协议: php://filter、php://input、php://filter用于读取源码 php://input用于执行php代码 2.其次,判断使用php://input伪协议 而执行php://input伪协议条件是allow_url_include是On 可以先利用…...

CTF show Web 红包题第六弹
提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框,很难让人不联想到SQL注入,但提示都说了不是SQL注入,所以就不往这方面想了 先查看一下网页源码,发现一段JavaScript代码,有一个关键类ctfs…...
Leetcode 3576. Transform Array to All Equal Elements
Leetcode 3576. Transform Array to All Equal Elements 1. 解题思路2. 代码实现 题目链接:3576. Transform Array to All Equal Elements 1. 解题思路 这一题思路上就是分别考察一下是否能将其转化为全1或者全-1数组即可。 至于每一种情况是否可以达到…...
Python 包管理器 uv 介绍
Python 包管理器 uv 全面介绍 uv 是由 Astral(热门工具 Ruff 的开发者)推出的下一代高性能 Python 包管理器和构建工具,用 Rust 编写。它旨在解决传统工具(如 pip、virtualenv、pip-tools)的性能瓶颈,同时…...

AirSim/Cosys-AirSim 游戏开发(四)外部固定位置监控相机
这个博客介绍了如何通过 settings.json 文件添加一个无人机外的 固定位置监控相机,因为在使用过程中发现 Airsim 对外部监控相机的描述模糊,而 Cosys-Airsim 在官方文档中没有提供外部监控相机设置,最后在源码示例中找到了,所以感…...
前端调试HTTP状态码
1xx(信息类状态码) 这类状态码表示临时响应,需要客户端继续处理请求。 100 Continue 服务器已收到请求的初始部分,客户端应继续发送剩余部分。 2xx(成功类状态码) 表示请求已成功被服务器接收、理解并处…...

python基础语法Ⅰ
python基础语法Ⅰ 常量和表达式变量是什么变量的语法1.定义变量使用变量 变量的类型1.整数2.浮点数(小数)3.字符串4.布尔5.其他 动态类型特征注释注释是什么注释的语法1.行注释2.文档字符串 注释的规范 常量和表达式 我们可以把python当作一个计算器,来进行一些算术…...

构建Docker镜像的Dockerfile文件详解
文章目录 前言Dockerfile 案例docker build1. 基本构建2. 指定 Dockerfile 路径3. 设置构建时变量4. 不使用缓存5. 删除中间容器6. 拉取最新基础镜像7. 静默输出完整示例 docker runDockerFile 入门syntax指定构造器FROM基础镜像RUN命令注释COPY复制ENV设置环境变量EXPOSE暴露端…...

WinUI3开发_使用mica效果
简介 Mica(云母)是Windows10/11上的一种现代化效果,是Windows10/11上所使用的Fluent Design(设计语言)里的一个效果,Windows10/11上所使用的Fluent Design皆旨在于打造一个人类、通用和真正感觉与 Windows 一样的设计。 WinUI3就是Windows10/11上的一个…...

2025-06-01-Hive 技术及应用介绍
Hive 技术及应用介绍 参考资料 Hive 技术原理Hive 架构及应用介绍Hive - 小海哥哥 de - 博客园https://cwiki.apache.org/confluence/display/Hive/Home(官方文档) Apache Hive 是基于 Hadoop 构建的数据仓库工具,它为海量结构化数据提供类 SQL 的查询能力…...

搭建nginx的负载均衡
1、编写一个configMap的配置文件 events {worker_connections 1024; # 定义每个worker进程的最大连接数 }http {# 定义通用代理参数(替代proxy_params文件)proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-F…...