【Mybatis】我抄袭了Mybatis,手写一套MyMybatis框架:初窥mybatis源码

2024-01-18 11:36

本文主要是介绍【Mybatis】我抄袭了Mybatis,手写一套MyMybatis框架:初窥mybatis源码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在历经之前几章课程的深入学习之后,我想我们已经初步掌握了如何运用jdbc连接数据库的技术;同时,我们也实现了利用mybatis框架的能力,甚至尝试着手编写、实现了ORM的框架。我坚信大家对MyBatis的理解和应用已经达到了一定程度。然而,你们是否有思考过为何MyBatis能够具备如此强大的效能呢?因此,在本次课程中,我们将全面剖析MyBatis的源代码,以此揭示其背后隐藏着的卓越功能的实现原理。为了方便我们的Debug实验,我们仍然会参考并使用在上一章节课程所提到的Mybatis-Demo模块进行操作。

文章目录

    • 第一行(获取xml配置文件)
    • 第二行(解析xml文件内容)
    • 第三行(构建DefaultSqlSession对象)
    • 第四行(开始执行查询方法)

在接下来的探究过程中,我们首要需要的就是MyBatis的源代码。建议各位同学可以登录mybatis官方网站获取并下载该源代码(地址为:https://github.com/mybatis/mybatis-3)。

在这里插入图片描述

我们首先可以看到我们的启动类是这样的

package com.masiyi;import com.masiyi.dao.UserDao;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;
import java.io.InputStream;/*** @Author masiyi* @Date ${DATE}* @PackageName:com.masiyi* @ClassName: ${NAME}* @Description: TODO* @Version 1.0*/
public class Main {public static void main(String[] args) throws IOException {InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);try (SqlSession session = sqlSessionFactory.openSession()) {UserDao mapper = session.getMapper(UserDao.class);mapper.findById(1).forEach(System.out::println);System.out.println("----------------------------");mapper.findAll().forEach(System.out::println);}}
}

第一行(获取xml配置文件)

就和上一篇文章一样。第一行的意思就是引入我们的mybatis的配置文件。这个配置文件要在我们的resource资源目录下面。我们现在去看这个resource类做了哪些动作?

在这里插入图片描述

经过这个方法之后,我们可以看到他需要调类加载器的getResourceAsStream这个方法。

在这里插入图片描述

最终把我们的传进来这个字符串给转化为url。

在这里插入图片描述

实际上他根据我们的类加载器找到了这个配置文件在我们本机环境下的绝对路径。这样他就能根据绝对路径转化为一个输入流。方便我们后续的读配置文件的要求。

在这里插入图片描述

运行完第一行之后,我们的目的就完成了,他最终给我们的是一个输入流。

在这里插入图片描述

第二行(解析xml文件内容)

第二行我们可以看到它其实进入了一个build的重载方法。第二个参数和第三个参数全都是null,他也就是说只传入了我们第一行代码,给过我们的输入流。通过我们的输入流,他给我们建造了一个XMLConfigBuilder对象。这个对象的目的就是用来解析我们的xml的配置文件。就有点类似于我们mymybatis里面的ConfigParse文件。

在这里插入图片描述

因为我们有了这个对象,所以我们可以直接去调用里面的pass方法去解析。所以说这个pass里面的方法基本上囊括了我们xml文件中所有配置的标签。都在这里进行一个解析。

在这里插入图片描述

我们进入到这个方法里面,就可以看到很多熟悉的标签。而xml文件里面能配置的标签基本上都在这里。

在这里插入图片描述

我们再来看一下我们的配置文件长什么样子?

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql://masiyi.obmtj0gc1rgs0ho0-mi.oceanbase.aliyuncs.com:3306/test_ob"/><property name="username" value="rootmsy"/><property name="password" value="Msy18719255298"/></dataSource></environment></environments><mappers><mapper resource="mapper/UserMapper.xml"/></mappers>
</configuration>

所以说,我们直接看environments 这个标签里面他就是我们要解析的,其他都是我们没有写,所以他直接就return直接跳过了。

在这里插入图片描述

我们在这个方法里面看到了。他读取到了xml文件里面数据库相关的信息。他都把它存在这里。之后把configuration的Environment这个属性给他set值。

在这里插入图片描述

之后在mapperElement方法里面也解析了我们插面文件里面的mapper节点里面的信息。

在这里插入图片描述

这些操作解析完了之后,我们返回了一个DefaultSqlSessionFactory这个实体类,并且把我们刚刚构建了configuration这个类给赋值进去。所以说这个第二行它的目的就是解析我们的xml文件。并把里面所有的信息都解析出来配置给configuration这个类。

在这里插入图片描述

第三行(构建DefaultSqlSession对象)

在这里插入图片描述

最后进入到了这个openSessionFromDataSource方法,这个方法我里面我们可以看到他通过配置对象进行了很多相关的操作,比如说我们创建一个事物,我们构建事物的对象。如果说熟悉我们自己写框架,我们可以看到它也是New了一个执行器出来。最后他把这些串联出来的对象全部封装成一个DefaultSqlSession对象给返回出去。

在这里插入图片描述

第四行(开始执行查询方法)

熟悉我们自定义框架的同学,看到这一步就知道了。他通过 session.getMapper创建出来的对象其实是一个代理对象。他真正执行的方法都是被我们的mybatis全部给代理了。

我们进入findById这个方法里面可以看到它其实走的我是我们invoke方法。

在这里插入图片描述

到了这一步,可谓我们终于见到了my buddies的庐山真面目,她执行了invoke方法,里面会最终进入到这个方法,这个方法的作用其实就是解析我们的增删改查。例如我们的xml文件里面写的是select方法,它就会走到对应的枚举类里面去。

在这里插入图片描述

相信看到这里的同学已经特别特别特别熟悉了。根据传进来的statement我们可以找到。Configuration里面mappedStatements。对应的MappedStatement

在这里插入图片描述

到了这里。学习了我们jdbc连接MySQL的课程时候就非常的熟悉了。看到这些变量和类,这些不就是我们前面第一节课学到的类吗?

在这里插入图片描述

最终还是通过execute方法,也就是jdbc里面的方法。执行了SQL。最终获得了结果。

在这里插入图片描述

最后根据SQL查询到的结果封装成我们的resultType属性里面对应的类

在这里插入图片描述

至此,我们的课程就学完了。我们已经知道了mybatis的最基本的操作大家感兴趣的可以去我的代码仓库里面去查看详细的代码
https://gitee.com/WangFuGui-Ma/my-mybatis。

哦,对了。感谢博学谷的子慕老师提供的mybatis源码(带注释的内容)。

在这里插入图片描述

另外如果对Elastic Search感兴趣的话,推荐一下我的专栏,这篇专栏介绍了Elasticsearch的Restful API的入门指南。学习如何使用API进行索引、搜索和分析,包括创建索引、定义映射、添加文档、执行查询等。通过实例和代码片段,快速上手Elasticsearch的Restful API,构建强大的搜索功能。感谢大家支持:

Elastic Search的RestFul API入门

在这里插入图片描述

这篇关于【Mybatis】我抄袭了Mybatis,手写一套MyMybatis框架:初窥mybatis源码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二:

Java 正则表达式URL 匹配与源码全解析

《Java正则表达式URL匹配与源码全解析》在Web应用开发中,我们经常需要对URL进行格式验证,今天我们结合Java的Pattern和Matcher类,深入理解正则表达式在实际应用中... 目录1.正则表达式分解:2. 添加域名匹配 (2)3. 添加路径和查询参数匹配 (3) 4. 最终优化版本5.设计思

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进

将Mybatis升级为Mybatis-Plus的详细过程

《将Mybatis升级为Mybatis-Plus的详细过程》本文详细介绍了在若依管理系统(v3.8.8)中将MyBatis升级为MyBatis-Plus的过程,旨在提升开发效率,通过本文,开发者可实现... 目录说明流程增加依赖修改配置文件注释掉MyBATisConfig里面的Bean代码生成使用IDEA生

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S