MyBatis

手写MyBatis流程

架构流程图

封装数据

封装到Configuration中

1、封装全局配置文件,包含数据库连接信息和mappers信息

2、封装*mapper.xml映射文件

封装操作:Builder类

Builder类用来操作配置文件(全局配置文件和mapper映射文件),将配置数据封装到类中。

XmlConfigBuilder

提供parse方法将dataSource信息封装到Configuration

XmlMapperBuilder

提供parse方法将mapper.xml信息封装到Configuration

XmlStatementBuilder

提供parse方法封装MappedStatement信息(此处应用了创建者模式)

XmlScriptBuilder

提供parse方法封装SqlNode信息

数据封装类:

Configuration

封装DataSource和MappedStatement

注意:在Configuration中还提供了创建四大组件的功能!!!

DataSource

封装了连接数据库所需的四大属性:数据库驱动、url、username、passwrod

MappedStatement

每一个CRUD标签都对应一个MappedStatement,其中包含了标签类型(StatementType)、参数类型(ParameterType)、结果类型(ResultType)、Sql文本包装类(SqlSource)

SqlSource

此接口只是对SqlNode做了一些包装,并提供getBound方法,用来获取sql文本和参数列表

1、StaticSqlSource

包含已经解析过的sql文本和参数信息(名称和类型)列表

2、RawSqlSource

用来封装只包含#{}的SqlNode

在其构造方法中,实现了以下操作:

(1)调用SlqNode的apply方法,拼接sql文本

(2)将#{}替换成?

(3)生成StaticSqlSource

在其getBound方法中,实现了以下操作:

将构造参数中生成的StaticSqlSource转化成BoundSql

2、DynamicSqlSource

用来封装包含${}的SqlNode,在getBound方法中,实现了以下操作:

(1)调用SlqNode的apply方法,拼接sql文本

(2)将#{}替换成?

(3)生成BoundSql

注意:因为含有${},解析时需要替换成参数值,所以每次传入不同的参数,都需要调用此方法,重新生成可执行的sql。

SqlNode

不同的SqlNode实现封装了不同类型的Sql文本,并提供了apply方法,用来将sql文本拼接到全局变量DynamicContext中

遍历mapper.xml文件,将不同的Node封装到不同的SqlNode实现类中。

1、StaticSqlNode

用来封装只包含#{}的sql文本。

2、TextSqlNode

用来封装包含${}的sql文本。并在其apply方法中解析了${},将${}替换成相应的参数值。

3、IfSqlNode

用来封装If标签的sql文本。

4、MixSqlNode

用来封装SqlNode集合。并在其apply方法中遍历了集合,并调用了每个元素的apply方法。(此处用到了组合模式)

如下mapper.xml文件对应的SqlNode:

mapper.xml映射文件:

对应生成的MixedSqlNode:

BoundSql

封装JDBC可执行的sql文本和参数信息(参数名、参数类型)列表

执行JDBC

SqlSession

提供CRUD方法,用户可以直接调用。

DefaultSqlSession
SqlSessionFactory

SqlSession工厂

DefaultSqlSessionFactory
SqlSessionFactoryBuilder(构建者模式)

用configuration创建SqlSession????

JDBC四大组件

Executor

执行器,执行JDBC。其中涉及一级缓存和二级缓存。

BaseExecutor

实现了Executor接口,提供query方法,如果存在一级缓存,那么返回一级缓存的数据;如果不存在一级缓存,则从数据库查询

SimpleExecutor(应用了里氏替换原则)

继承了BaseExecutor,忽略了二级缓存的存在,直接从数据库查询数据。

CachingExecutor

继承了BaseExecutor,如果存在二级缓存,使用二级缓存,否则从数据库查询。

StatementHandler

创建statement对象,执行JDBC操作。StatementHandler的实现类有PreparedStatementHandler、CallableStatementHandler、SimpleStatementHandler。此处应用了策略模式,每个实现类提供了不同的策略。

ParameterHandler

参数处理器,将参数信息添加到statement中

ResultHandler

对结果ResultSet进行处理,转化成List<Object>

手写mybatis框架笔记的更多相关文章

  1. 要想精通Mybatis?从手写Mybatis框架开始吧!

    1.Mybatis组成 动态SQL Config配置 Mapper配置 2.核心源码分析 Configuration源码解析 SqlSessionFactory源码解析 SqlSession源码解析 ...

  2. 手写mybatis框架-增加缓存&事务功能

    前言 在学习mybatis源码之余,自己完成了一个简单的ORM框架.已完成基本SQL的执行和对象关系映射.本周在此基础上,又加入了缓存和事务功能.所有代码都没有copy,如果也对此感兴趣,请赏个Sta ...

  3. 手写mybatis框架

    前言 很久没有更新mybatis的源码解析了,因为最近在将自己所理解的mybatis思想转为实践. 在学习mybatis的源码过程中,根据mybatis的思想自己构建了一个ORM框架 .整个代码都是自 ...

  4. 手写MyBatis ORM框架实践

    一.实现手写Mybatis三个难点 1.接口既然不能被实例化?那么我们是怎么实现能够调用的? 2.参数如何和sql绑定 3.返回结果 下面是Mybatis接口 二.Demo实现 1.创建Maven工程 ...

  5. MyBatis 框架笔记

    Mybatis 框架笔记   ------技术源于热爱! 获取更多内容请关注小编的个人微信公众平台 1       Mybatis入门 1.1     单独使用jdbc编程问题总结 1.1.1  jd ...

  6. 手写Spring框架,加深对Spring工作机制的理解!

    在我们的日常工作中,经常会用到Spring.Spring Boot.Spring Cloud.Struts.Mybatis.Hibernate等开源框架,有了这些框架的诞生,平时的开发工作量也是变得越 ...

  7. 带码农《手写Mybatis》进度3:实现映射器的注册和使用

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获!

  8. Spring 08: AOP面向切面编程 + 手写AOP框架

    核心解读 AOP:Aspect Oriented Programming,面向切面编程 核心1:将公共的,通用的,重复的代码单独开发,在需要时反织回去 核心2:面向接口编程,即设置接口类型的变量,传入 ...

  9. 手写 jQuery 框架

    1.测试页面; <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...

随机推荐

  1. Go语言实现:【剑指offer】左旋转字符串

    该题目来源于牛客网<剑指offer>专题. 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果.对于一个给定的字符序列S,请你把其循环左 ...

  2. Python原来这么好学-1.2节: 在Linux中安装python

    这是一本教同学们彻底学通Python的高质量学习教程,认真地学习每一章节的内容,每天只需学好一节,帮助你成为一名卓越的Python程序员: 本教程面向的是零编程基础的同学,非科班人士,以及有一定编程水 ...

  3. 图像数组运算相关问题(nan/inf)

    新年第一更!祝愿新的一年技术长足进步哈! 最近在用sklearn的回归分析模型拟合预测遥感图像,遇到了一些问题,好在一一解决,现在总结一下. 1.首先输入sklearn的数据必须reshape(-1, ...

  4. 12-MyBatis02

    今日知识 1. 关联查询 2. 延时加载 3. 查询缓存 关联查询 1.一对一 resultType实现 1. 写个定单的扩展类 public class OrdersExt extends Orde ...

  5. ELF文件之四——使用链接脚本-2个函数-data

    main.c ; int main() { ; } int add() { ; } main.o 反汇编可以看到多了.text节的反汇编,存储的是全局变量的初始化数值 main.o对比,text段后面 ...

  6. 风物长宜放眼量,人间正道是沧桑 - 一位北美 IT 技术人破局

    引言 我对于本科时光的印象,还停留在那所普通 211 大学的建筑物之间,我坐在大学的时光长廊里,满眼望去,都是经历的过的故事.可毕业后回首,却很少有人能说,自己从来没有迷茫过.迷茫,仿佛就是一团乌云, ...

  7. xmake v2.3.1 发布, 无缝对接其他构建系统

    最近对xmake内部做了不少的重构来改进,并且新增了不少实用的新特性,欢迎来体验. 项目源码 官方文档 一些新特性: 一键编译其他构建系统维护的项目,实现无缝对接,并且支持交叉编译(比如autotoo ...

  8. 4,ZooKeeper原理

    1,ZooKeeper概述 ··· 作用:     · ZooKeeper是为分布式应用程序提供的一个分布式开源协调框架,是Hadoop和Hbase的重要组件:     · 主要用于解决分布式集群中应 ...

  9. MySql存储引擎:innodb myisan memory

    一.MySQL存在的常用存储引擎 存储引擎就是指表的类型,数据库的存储引擎决定了表在计算机中的存储方式. 使用show  engines; (show engines\G;)可查看数据库支持的存储引擎 ...

  10. Git简易教程(常用命令)

    本文章参考了Pro Git 1 Git简介 Linux内核开源项目有着众多参与者,为了提高开发效率,项目组于2002年开始启用分布式版本控制系统BitKeeper来管理和维护代码.在BitKeeper ...