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

相关文章

Git打标签从本地创建到远端推送的详细流程

《Git打标签从本地创建到远端推送的详细流程》在软件开发中,Git标签(Tag)是为发布版本、标记里程碑量身定制的“快照锚点”,它能永久记录项目历史中的关键节点,然而,仅创建本地标签往往不够,如何将其... 目录一、标签的两种“形态”二、本地创建与查看1. 打附注标http://www.chinasem.cn

Nginx屏蔽服务器名称与版本信息方式(源码级修改)

《Nginx屏蔽服务器名称与版本信息方式(源码级修改)》本文详解如何通过源码修改Nginx1.25.4,移除Server响应头中的服务类型和版本信息,以增强安全性,需重新配置、编译、安装,升级时需重复... 目录一、背景与目的二、适用版本三、操作步骤修改源码文件四、后续操作提示五、注意事项六、总结一、背景与

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

mybatis映射器配置小结

《mybatis映射器配置小结》本文详解MyBatis映射器配置,重点讲解字段映射的三种解决方案(别名、自动驼峰映射、resultMap),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定... 目录select中字段的映射问题使用SQL语句中的别名功能使用mapUnderscoreToCame

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

mybatis-plus如何根据任意字段saveOrUpdateBatch

《mybatis-plus如何根据任意字段saveOrUpdateBatch》MyBatisPlussaveOrUpdateBatch默认按主键判断操作类型,若需按其他唯一字段(如agentId、pe... 目录使用场景方法源码方法改造首先在service层定义接口service层接口实现总结使用场景my