3.MyBatis源码解析-CRUD执行流程--阿呆中二

2024-09-07 10:58

本文主要是介绍3.MyBatis源码解析-CRUD执行流程--阿呆中二,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CRUD执行流程

  • MyBatis
    • CRUD执行流程
    • 与我联系

MyBatis

本文是对mybatis 3.x源码深度解析与最佳实践学习的总结,包括XML文件解析流程SqlSession构建流程CRUD执行流程MyBatis扩展点,以及针对面试题进行源码分析。

mybatis 3.x源码深度解析与最佳实践下载:https://download.csdn.net/download/u013425841/12816685

CRUD执行流程

MyBatis执行的基本流程大致可以分四个步骤:

  1. 使用Resources类加载Mybatis的Xml配置文件
  2. 使用SqlSessionFactoryBuilder构建SqlSessionFactory对象
  3. 使用SqlSessionFactory对象调用openSession获取SqlSession
  4. 使用SqlSessioon对象调用select\update\delete等方法进行操作
public static void main(String[] args) {try {Reader reader;// 1.加载mybatis configuration配置文件String resource = "Configuration.xml";reader = Resources.getResourceAsReader(resource);// 2.使用SqlSessionFactoryBuilder构建SqlSessionFactory对象SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader);// 3.构建SqlSession对象SqlSession session = sessionFactory.openSession();try {//4.执行数据库查询User user = (User) session.selectOne("com.mybatis.source.mapper.UserMapper.getUser", 1);System.out.println(user.getAge() + "," + user.getName());} finally {session.close();}} catch (IOException e) {e.printStackTrace();}

今天重点分析CRUD执行流程,主要对应代码

        //第一种方式 直接使用selectOne方法User user = session.selectOne("com.mybatis.source.mapper.UserMapper.getUser", 1);//第二种方式 使用动态代理最终还是调用session提供的方法,比如selectOneUserMapper mapper = session.getMapper(UserMapper.class);//mapper是已经被代理的类,所以执行的时候会被动态代理拦截,最终调用selectOneUser user3 = mapper.getUser(1);

因为getMapper最终还会调用到selectOne方法,因此我们分析第二种getMapper方式。

进入源码分析:

	UserMapper mapper = session.getMapper(UserMapper.class);

在这里插入图片描述
1.getMapper方法首先从knownMappers对象中,获取当前传入的Class对应的MapperProxyFactory工厂类
注意:knowMappers的内容是在解析XML过程中,我们有提到的一个步骤,是在进行addMapper的时候进行put操作的,创建了一个mapper的代理工厂
在这里插入图片描述

2.调用newInstance方法生成代理类,MapperProxy负责具体代理后的逻辑处理
在这里插入图片描述
上面就返回Mapper的代理类,下面继续看执行流程:

User user3 = mapper.getUser(1);

1.上面已经知道mapper是代理类,并且知道代理的主要逻辑在MapperProxy中

因此执行getUser会执行MapperProxy中的invoke方法,invoke方法调用cachedInvoker方法,返回一个PlainMethodInvoker方法
在这里插入图片描述

2.拿到PlainMethodInvoker对象执行invoke方法
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
上面可以看出最终还会委托sqlSession对象,执行selectOne等操作,到此继续执行就和第一种逻辑开始一致。

继续看sqlSession.selectOne方法执行逻辑:
在这里插入图片描述
可以看到委托给selectList方法
在这里插入图片描述
可以看到使用当时解析好的执行器进行查询
在这里插入图片描述
本文使用的SimpleExecutor,query的实现是继承BaseExecutor类的query方法,执行器都继承这个类,公用部分在BaseExecutor里

可以看到这里进行一级缓存和调用queryFromDataBase进行底层jdbc的操作
在这里插入图片描述
queryFromDataBase方法,具体doQuery实现在子类
在这里插入图片描述
看看SimpleExecutor执行器的doQuery方法,执行jdbc操作,并且封装返回结果
在这里插入图片描述
大致的执行流程就是这样,如果有需要更详细的内容,可以留言反馈哈

在这里插入图片描述

与我联系

Java/一对一零基础辅导/公司项目一对一辅导/日常Bug解决/代码讲解/毕业设计等 微信:study_51ctofx

这篇关于3.MyBatis源码解析-CRUD执行流程--阿呆中二的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1144876

相关文章

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

深度解析Python装饰器常见用法与进阶技巧

《深度解析Python装饰器常见用法与进阶技巧》Python装饰器(Decorator)是提升代码可读性与复用性的强大工具,本文将深入解析Python装饰器的原理,常见用法,进阶技巧与最佳实践,希望可... 目录装饰器的基本原理函数装饰器的常见用法带参数的装饰器类装饰器与方法装饰器装饰器的嵌套与组合进阶技巧

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决