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

相关文章

Agent开发核心技术解析以及现代Agent架构设计

《Agent开发核心技术解析以及现代Agent架构设计》在人工智能领域,Agent并非一个全新的概念,但在大模型时代,它被赋予了全新的生命力,简单来说,Agent是一个能够自主感知环境、理解任务、制定... 目录一、回归本源:到底什么是Agent?二、核心链路拆解:Agent的"大脑"与"四肢"1. 规划模

MyBatis-Plus逻辑删除实现过程

《MyBatis-Plus逻辑删除实现过程》本文介绍了MyBatis-Plus如何实现逻辑删除功能,包括自动填充字段、配置与实现步骤、常见应用场景,并展示了如何使用remove方法进行逻辑删除,逻辑删... 目录1. 逻辑删除的必要性编程1.1 逻辑删除的定义1.2 逻辑删php除的优点1.3 适用场景2.

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

MyBatis配置文件中最常用的设置

《MyBatis配置文件中最常用的设置》文章主要介绍了MyBatis配置的优化方法,包括引用外部的properties配置文件、配置外置以实现环境解耦、配置文件中最常用的6个核心设置以及三种常用的Ma... 目录MyBATis配置优化mybatis的配置中引用外部的propertis配置文件⚠️ 注意事项X

MyBatis中的两种参数传递类型详解(示例代码)

《MyBatis中的两种参数传递类型详解(示例代码)》文章介绍了MyBatis中传递多个参数的两种方式,使用Map和使用@Param注解或封装POJO,Map方式适用于动态、不固定的参数,但可读性和安... 目录✅ android方式一:使用Map<String, Object>✅ 方式二:使用@Param

MyBatis-Plus使用动态表名分表查询的实现

《MyBatis-Plus使用动态表名分表查询的实现》本文主要介绍了MyBatis-Plus使用动态表名分表查询,主要是动态修改表名的几种常见场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录1. 引入依赖2. myBATis-plus配置3. TenantContext 类:租户上下文

SQL 注入攻击(SQL Injection)原理、利用方式与防御策略深度解析

《SQL注入攻击(SQLInjection)原理、利用方式与防御策略深度解析》本文将从SQL注入的基本原理、攻击方式、常见利用手法,到企业级防御方案进行全面讲解,以帮助开发者和安全人员更系统地理解... 目录一、前言二、SQL 注入攻击的基本概念三、SQL 注入常见类型分析1. 基于错误回显的注入(Erro

Spring Boot 集成 mybatis核心机制

《SpringBoot集成mybatis核心机制》这篇文章给大家介绍SpringBoot集成mybatis核心机制,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值... 目录Spring Boot浅析1.依赖管理(Starter POMs)2.自动配置(AutoConfigu

在SpringBoot+MyBatis项目中实现MySQL读写分离的实战指南

《在SpringBoot+MyBatis项目中实现MySQL读写分离的实战指南》在SpringBoot和MyBatis项目中实现MySQL读写分离,主要有两种思路:一种是在应用层通过代码和配置手动控制... 目录如何选择实现方案核心实现:应用层手动分离实施中的关键问题与解决方案总结在Spring Boot和

使用MyBatis TypeHandler实现数据加密与解密的具体方案

《使用MyBatisTypeHandler实现数据加密与解密的具体方案》在我们日常的开发工作中,经常会遇到一些敏感数据需要存储,比如用户的手机号、身份证号、银行卡号等,为了保障数据安全,我们通常会对... 目录1. 核心概念:什么是 TypeHandler?2. 实战场景3. 代码实现步骤步骤 1:定义 E