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

相关文章

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

全面解析Golang 中的 Gorilla CORS 中间件正确用法

《全面解析Golang中的GorillaCORS中间件正确用法》Golang中使用gorilla/mux路由器配合rs/cors中间件库可以优雅地解决这个问题,然而,很多人刚开始使用时会遇到配... 目录如何让 golang 中的 Gorilla CORS 中间件正确工作一、基础依赖二、错误用法(很多人一开

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

MyBatis-Plus 自动赋值实体字段最佳实践指南

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与... 目录1. MyBATis-Plus 自动赋值概述1.1 适用场景1.2 自动填充的原理1.3 填充策略

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理