MyBatis实现与插件开发

分析源码之前也需要源码下载并安装到本地仓库和开发工具中,方便给代码添加注释;安装过程和mybatis源码的安装过程是一样的,这里就不再重复描述了;下载地址:https://github.com/mybatis/spring

  1、SqlSessionFactoryBean源码分析

  2、MapperFactoryBean源码分析

  3、MapperScannerConfigurer源码分析

插件开发原理

插件是用来改变或者扩展mybatis的原有的功能,mybaits的插件就是通过继承Interceptor拦截器实现的;

在没有完全理解插件之前禁止使用插件对mybaits进行扩展,又可能会导致严重的问题;

mybatis中能使用插件进行拦截的接口和方法如下:

  Executor(update、query 、 flushStatment 、 commit 、 rollback 、 getTransaction 、 close 、 isClose)

  StatementHandler(prepare 、 paramterize 、 batch 、 update 、 query)

  ParameterHandler( getParameterObject 、 setParameters )

  ResultSetHandler( handleResultSets 、 handleCursorResultSets 、 handleOutputParameters )

插件开发快速入门

定义一个阈值,当查询操作运行时间超过这个阈值记录日志供运维人员定位慢查询,插件实现步骤:

  1、实现Interceptor接口方法

  2、确定拦截的签名

  3、在配置文件中配置插件

  4、运行测试用例

源码分析之责任链模式

责任链模式:就是把一件工作分别经过链上的各个节点,让这些节点依次处理这个工作;和装饰器模式不同,每个节点都知道后继者是谁;适合为完成同一个请求需要多个处理类的场景;

要素分析

  Handler:定义了一个处理请求的标准接口;

  ConcreteHandler:具体的处理者,处理它负责的部分,根据业务可以结束处理流程,也可以将请求转发给它的后继者;

  client :发送者,发起请求的客户端;  

责任链模式优点:

   降低耦合度。它将请求的发送者和接收者解耦。

  简化了对象。使得对象不需要知道链的结构。

  增强给对象指派职责的灵活性。通过改变链内的成员或者调动它们的次序,允许动态地新增或者删除责任。

  增加新的请求处理类很方便。

mybatis插件模块源码分析

  插件的初始化 (XMLConfigBuilder.pluginElement)

  插件的加载 (Configuration.new*方法,四大对象的创建)

  插件的调用 (Plugin. wrap、 Plugin. invoke)

mybatis插件理解:

https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/Interceptor.md

Mybatis分页插件PageHelper

  

分页插件的使用;

  中文文档:https://github.com/pagehelper/Mybatis-PageHelper/blob/master/README_zh.md

  使用手册:https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/HowToUse.md

分页插件的注意事项;

  注意事项:https://github.com/pagehelper/Mybatis-PageHelper/blob/master/wikis/zh/Important.md

分页插件的源码概述;

自己实现mybatis

MyBatis核心流程三大阶段

初始化阶段

读取XML配置文件和数据库配置文件中的信息加载到configuration对象中;

SqlSession示意图

话说SqlSession

Sqlsession意味着创建数据库会话,代表了一次与数据库的连接;

   是MyBatis对外提供数据访问的主要API(试试iBatis编程的方式吧);

   实际上Sqlsession的功能都是基于Excutor来实现的;

SqlSession查询接口嵌套关系:

为什么要有代理阶段?

Executor组件分析

Executor是MyBaits核心接口之一,定义了数据库操作最基本的方法; Executor对数据库的操作遵循什么样规范?

简化版MyBatis实现思路

原文地址:https://www.cnblogs.com/Soy-technology/p/11495024.html

时间: 2024-08-08 05:29:03

MyBatis实现与插件开发的相关文章

深入理解Mybatis插件开发

背景 关于Mybatis插件,大部分人都知道,也都使用过,但很多时候,我们仅仅是停留在表面上,知道Mybatis插件可以在DAO层进行拦截,如打印执行的SQL语句日志,做一些权限控制,分页等功能:但对其内部实现机制,涉及的软件设计模式,编程思想往往没有深入的理解. 本篇案例将帮助读者对Mybatis插件的使用场景,实现机制,以及其中涉及的编程思想进行一个小结,希望对以后的编程开发工作有所帮助. 注:本案例以mybatis 3.4.7-SNAPSHOT版本为例. PS:文章是挺久之前写的,当时花了

mybatis插件开发

1. 插件初始化 MyBATIS是在初始化上下文环境的时候就初始化插件的,我们看到源码: 它最后是把所有的插件按你配置的顺序保存在一个list对象里面. 3.插件的取出: MyBATIS的插件可以拦截Executor,StatementHandler,ParameterHandler和ResultHandler对象(下简称四大对象)

mybatis插件开发初探

运行流程: /** * 1.获取sqlSessionFactory对象: * 解析文件的每一个信息保存在Configuration中,返回包含Configuration的DefaultSqlSession: * 注意:[MappedStatement]:代表一个增删改查的详细信息 * * 2.获取sqlSession对象 * 返回一个DefaultSQlSession对象,包含Executor和Configuration; * 这一步会创建Executor对象: * * 3.获取接口的代理对象(

mybatis源码分析(6)-----核心调度对象StatmentHandler

写在前面 通过上一偏文章,我们知道:mybatis 的插件开发,主要是集中在Executor(执行器),ParameterHandler(参数处理器),ResultSetHandler(结果集处理器),StatementHandler( 语句处理器). 我们知道了mybatis对外暴露的API(SqlSession)的操作,其实是其持有Executor对于底层的操作.也知道了Executor 的设计采用了模板方法模式. 查看Executor 的源代码发现,它对底层的操作,其实是其持有Statme

深入浅出MyBatis:JDBC和MyBatis介绍

最近在休陪产假,时间比较零碎,准备看2本书充实下,一本是「深入浅出MyBatis:技术原理与实践」,一本是「RabbitMQ实战:高效部署分布式消息队列」,为了加深记忆和理解,会进行整理.扩展和记录. 看书的目标不是把所有的细节都记住,而是从整体上了解一个技术能做什么,包含的特性.基本模块,实现原理和常见使用场景. 本篇分享MyBatis书籍的第一篇,首先回忆下JDBC的相关概念,了解Java提供的访问数据库最基本的方式,然后介绍下MyBatis的基本特性和核心组件,最后说下书的整体结构,了解后

【Mybtais】Mybatis 插件 Plugin开发(一)动态代理步步解析

需求: 对原有系统中的方法进行'拦截',在方法执行的前后添加新的处理逻辑. 分析: 不是办法的办法就是,对原有的每个方法进行修改,添加上新的逻辑:如果需要拦截的方法比较少,选择此方法到是会节省成本.但是面对成百上千的方法怎么办?此时需要用到动态代理来实现. 场景: 例如:对原有的系统添加日志记录.添加性能分析等等... 举例: 如下,需要对Sleep对象的sleep方法进行"拦截",并在此方法的执行前后添加新的逻辑.想知道'睡觉前干了什么?睡觉后干了什么?' interface Sle

java框架之mybatis

一.简介 1.概念 mybatis 是一个半自动轻量级的一个 orm 框架 2.作用 将 java 与 sql 分离,解决了 jdbc 的硬编码问题,方便 sql 的修改: sql 由开发人员控制,更加方便 sql 的调优: 3.快速开始 (1)原始方法 建一个全局配置文件,里面是数据源等运行环境的信息: 建立一个sql 的映射文件,并将这个文件注册到全局的配置中: 根据全局的配置文件获得一个 sqlsessionfactory: 通过 factory 获得 sqlsession(非线程安全),

面试官问你MyBatis SQL是如何执行的?把这篇文章甩给他

初识 MyBatis MyBatis 是第一个支持自定义 SQL.存储过程和高级映射的类持久框架.MyBatis 消除了大部分 JDBC 的样板代码.手动设置参数以及检索结果.MyBatis 能够支持简单的 XML 和注解配置规则.使 Map 接口和 POJO 类映射到数据库字段和记录. MyBatis 的特点 那么 MyBatis 具有什么特点呢?或许我们可以从如下几个方面来描述 MyBatis 中的 SQL 语句和主要业务代码分离,我们一般会把 MyBatis 中的 SQL 语句统一放在 X

使用MyBatis Generator自动生成实体、mapper和dao层

通过MyBatis Generator可以自动生成实体.mapper和dao层,记录一下怎么用的. 主要步骤: 关于mybatis从数据库反向生成实体.DAO.mapper: 参考文章:http://www.cnblogs.com/wangkeai/p/6934683.html第一种方式:main方法运行(推荐) 1.在pom.xml中加入插件依赖: 2.写mbgConfiguration.xml文件,jdbc.properties文件 3.写/SSM/src/main/java/main/Ge