mybatis框架(六)——核心技术与原理

2024-08-26 17:48

本文主要是介绍mybatis框架(六)——核心技术与原理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

引言

            衡量我们是否掌握一种知识,标准是我们对它核心技术和原理的掌握程度。

概述

            mybatis核心技术包括:反射和动态代理;mybatis运行原理分为俩部分,第一部分是读取配置文件缓存到Configuration对象,用以创建SqlSessionFactory,第二部分是SqlSession的执行过程。

内容

             一 核心技术

            1 反射技术

                 (1)好处:配置性大大提高,可以给很多配置设置参数,使得java应用程序能够顺利运行起来,大大提高了Java的灵活性和可配置性,降低模块之间的耦合。

                 (2)实例:通过反射技术去创建ReflectService对象,获取服务方法后通过反射调用

		import java.lang.reflect.InvocationTargetException;import java.lang.reflect.Method;public class ReflectService{/*** 服务方法* @param name -- 姓名*/public void sayHello(String name){System.err.println("hello" + name);}/*** 测试* @param args*/public static void main(String[] args) throw ClassNotFoundException,NoSuchMethodException, InstantiationException, IllegalAccessException,IllegalArgumentException, InvocationTargetException{//通过反射创建ReflectService对象Object service = Class.forName(ReflectService.class.getName()).newInstance();//获取服务方法——sayHelloMethod method = service.getClass().getMethod("sayHello", String.class);//反射调用方法method.invoke(service, "liming");}
}

            2 动态代理

                 (1)代理是什么?

                          在原有的服务上多加一个占位,通过这个占位控制服务的访问。简单理解就是大厨和前台服务员的关系,我们去吃饭,直接和前台服务员沟通要吃什么,不用考虑是哪个大厨做饭,做什么饭,怎么做的。在服务的层面上,这个服务员就是大厨的代理了,也就是代理服务。

                 (2)为什么使用代理模式

                          1)控制如何访问真正的服务对象,提供额外服务。

                          2)通过重写一些类来满足特定的需要。

                 (3)分类

                          1)JDK动态代理:由JDK的java.lang.reflect.*包支持,必须提供接口

                                  步骤:编写服务类和接口,这个是真正的服务提供者,在JDK代理中接口是必须的

                                             编写代理类,提供绑定和代理方法

                                  示例:第一步,编写服务接口                                          

			public interface HelloService{public void sayHello(String name);}
                                            第二步,编写服务接口实现类

			public class HelloServiceImpl implements HelloService{@Overridepublic void sayHello(String name){System.err.println("hello" + name);}}
                                            第三步,编写一个代理类,提供真实对象的绑定和代理方法。代理类的要求是实现InvocationHandler接口的代理方法,当一个对象被绑定后,执行其方法的时候就会进入到代理方法
				public class HelloServiceProxy implements InvocationHandler{//定义真实对象private Object target;/*** 真实对象绑定委托代理对象并返回一个代理类* @param target* @return*/public Object bind(Object target){//获取真实对象this.target = target;//取得代理对象return Proxy.newProxyInstance(target.getClass().getClassLoader,target.getClass().getInterfaces(),this);              //jdk代理需要提供接口}@Override/*** 通过代理对象调用真实对象方法会进入代理方法* @param proxy --代理对象* @param method --被调用方法* @param args --方法的参数*/public Object invoke(Object proxy,Method method,Object[] args) throws Throwable{System.err.println("####我是JDK冬天代理####");Object result = null;//反射方法前调用System.err.println("我准备说hello。");//执行方法,相当于调用HelloServiceImpl类的sayHello方法result = method.invoke(target,args);//反射方法后调用System.err.println("我说过hello了");return result;	}}
                                            第四步:测试客户端代码

				public class client{public static void main(String[] args){HelloServiceProxy HelloHandler = new HelloServiceProxy();HelloServiceProxy proxy = (HelloService)HelloHandler.bind(new HelloServiceImpl());proxy.sayHello("李明");}}

                          2)CGLIB代理:HelloService.java和HelloServiceImpl.java都不需要改变,实现CGLIB的代理类(MethodInterceptor)

                                 代码示例:

		public class HelloServiceCgLib implements MethodInterceptor{private Object target;/***创建代理对象**@param target*@return*/public Object getInstance(Object target){this.target = target;Enhancer enhancer = new Enhancer();enhancer.setSuperclass(this.target.getClass());//回调方法enhancer.setCallback(this);//创建代理对象return enhancer.create();}@Override//回调方法public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable{System.err.println("#####我是CGLIB的动态代理#####");//反射方法前调用System.err.println("我准备说hello");Object returnObj = proxy.invokeSuper(obj, args);//反射方法后调用System.err.println("我说过hello了");return returnObj;}}

        二 mybatis运行原理

            1 构建SqlSessionFactory过程

                  (1)客户端调用SqlSesisonFactoryBuilder.build,传入对象为SqlMapConfig文件流

                  (2)根据sqlMapCconfig文件流-->  创建XMLConfigBuilder对象

                  (3)直接创建XMLMapperEntityResolver,该对象是SqlMapConfig文件的DTD本地实例    作用:将远程DTD文件转化为本地文件

                  (4)根据sqlMapConfig文件流,确定校验,XMLMapperEntityResolver实例对象 -->创建XPathParser . XPathParser作用:根据Xpath表达式获取基本的DOM节点Node信息的操作

                  (5)根据传入的SqlMapConfig配置文件流--> 创建Document实例

                  (6)返回XMLConfigBuilder实例.实例变量中有一个属性parsed,parserd=false. 代表并没有进行解析

                  (7)调用XMLConfigBuilder实例实例的parse方法

                  (8)在parse方法中,调用该实例属性的XPathParser,让它去处理SqlMapConfig配置文件的的<configuration>节点对应的Node对象,然后依次解析此Node节点的子Node:properties, settings, typeAliases,typeHandlers,objectFactory, objectWrapperFactory, plugins, environments,databaseIdProvider, mappers

                 (9)将XML配置文件内的信息解析成Java对象Configuration

                 (10)将上一步创建的Cofiguration对象作为参数,来创建DefaultSqlSessionFactory对象

                 (11)返回一个DefaultSqlSessionFactory对象

            2 SqlSession运行过程

                  (1)运行图

              

                  (2)说明:SqlSession是通过Executor(执行器)创建StatementHandler来运行的,StatementHandler要经过下面三步:1)prepared预编译SQL , 2)parameterize设置参数, 3)query/update执行SQL

                    其中parameterize调用parameterHandler的方法设置参数,参数根据类型处理器typeHandler去处理。query/update方法是通过resultHandler继续处理结果的封装,如果是update的语句,返回整数;否则通过typeHandler处理结果类型,然后用ObjectFactory提供的规则组装对象,返回给调用者。

总结

            mybatis是目前流行的持久层框架,反射技术与动态代理是其核心的内幕技术,同时SqlSessionFactory的创建以及SqlSession运行原理是mybatis核心内容之一,另外一个核心内容就是配置文件与映射。mybatis从构建mapper配置文件再到核心文件配置,再到方法引入配置文件通过SqlSessionFactoryBuilder创建SqlSessionFactory,然后通过SqlSessionFactory打开SqlSession执行数据库的访问操作,完成数据持久化的操作。

这篇关于mybatis框架(六)——核心技术与原理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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.

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

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 类:租户上下文

Java 队列Queue从原理到实战指南

《Java队列Queue从原理到实战指南》本文介绍了Java中队列(Queue)的底层实现、常见方法及其区别,通过LinkedList和ArrayDeque的实现,以及循环队列的概念,展示了如何高效... 目录一、队列的认识队列的底层与集合框架常见的队列方法插入元素方法对比(add和offer)移除元素方法

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

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

Spring Boot 集成 mybatis核心机制

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

Spring IOC核心原理详解与运用实战教程

《SpringIOC核心原理详解与运用实战教程》本文详细解析了SpringIOC容器的核心原理,包括BeanFactory体系、依赖注入机制、循环依赖解决和三级缓存机制,同时,介绍了SpringBo... 目录1. Spring IOC核心原理深度解析1.1 BeanFactory体系与内部结构1.1.1