博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mybatis的原理
阅读量:4141 次
发布时间:2019-05-25

本文共 3163 字,大约阅读时间需要 10 分钟。

一、mybatis的主要成员

在这里插入图片描述

1. Configuration        MyBatis所有的配置信息都保存在Configuration对象之中,配置文件中的大部分配置都会存储到该类中2. SqlSession           作为MyBatis工作的主要顶层API,表示和数据库交互时的会话,完成必要数据库增删改查功能3. Executor             MyBatis执行器,是MyBatis 调度的核心,负责SQL语句的生成和查询缓存的维护4. StatementHandler 	封装了JDBC Statement操作,负责对JDBC statement 的操作,如设置参数等 5. ParameterHandler  	负责对用户传递的参数转换成JDBC Statement 所对应的数据类型6. ResultSetHandler   	负责将JDBC返回的ResultSet结果集对象转换成List类型的集合7. TypeHandler          负责java数据类型和jdbc数据类型(也可以说是数据表列类型)之间的映射和转换8. MappedStatement  	MappedStatement维护一条
节点的封装9. sqlSource 负责根据用户传递的parameterObject,动态地生成SQL语句,将信息封装到BoundSql对象中,并返回10.BoundSql 表示动态生成的SQL语句以及相应的参数信息

二、mybatis硬编码方式

1. 配置文件           			String configXml = "mybatis_config.xml";2. 加载配置获取流     			Reader reader = Resources.getResourceAsReader(configXml);3. 获取sqlSessionFactory工厂    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);4. 获取sqlSession				SqlSession sqlSession = sqlSessionFactory.openSession();5. 获取对应的mapper     		    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);6. 执行方法           			UserEntity user = userMapper.getUser(1);

三、mybatis原理

在这里插入图片描述

1. 加载mybatis全局配置文件(数据源、mapper映射文件等),解析配置文件,MyBatis基于XML配置文件生成Configuration,和一个个MappedStatement(包括了参数映射配置、动态SQL语句、结果映射配置),其对应着<select | update | delete | insert>标签项
2. SqlSessionFactoryBuilder通过Configuration对象生成SqlSessionFactory,用来开启SqlSession
3. SqlSession对象完成和数据库的交互
1)用户程序调用mybatis接口层api(即Mapper接口中的方法)2)SqlSession通过调用api的Statement ID找到对应的MappedStatement对象3)通过Executor(负责动态SQL的生成和查询缓存的维护)将MappedStatement对象进行解析,sql参数转化、动态sql拼接,生成jdbc Statement对象4)JDBC执行sql5)借助MappedStatement中的结果映射关系,将返回结果转化成HashMap、JavaBean等存储结构并返回

四、mybatis源码解读

1. 首先,SqlSessionFactoryBuilder去读取mybatis的配置文件,然后build一个DefaultSqlSessionFactory	1)主要是读取mybatis-config的配置信息,里面的配置都在这个阶段解析设置	2)也可以以配置SqlSessionFactoryBean的方式来加载配置文件2. 当我们获取到SqlSessionFactory之后,就可以通过SqlSessionFactory去获取SqlSession对象 	1)主要是DefaultSqlSessionFactory.openSessionFromDataSource()方法,会设置一些configuration和事务的配置信息3. 拿到SqlSession对象之后,还要有映射文件信息啊	1)可以通过配置MapperScannerConfigurer的Bean加载指定包下的Dao(加了@Repository?)	4. 在mybatis中,通过MapperProxy动态代理咱们的dao,也就是说,当咱们执行自己写的dao里面的方法的时候,其实是对应的mapperProxy在代理	1)执行dao的时候,MapperProxy.invoke()方法开始执行	2)调到MapperMethod根据sql的CRUD类型(select/updata/insert/delete)选择调sqlSession的哪个方法	3)也可以根据 sqlSession.getMapper(Class
type) 来获取mapper(其实生成的就是MapperProxy对象),再调mapper.定义的方法(会走1)2)的步骤) 4)一个是集成在spring的扫描包中,一个是直接通过编程方式获取,最终都是MapperProxy代理对象去执行,都会走到2)的判断CRUD5. 执行sqlSession的方法 selectOne/selectList/update ... 1)实现类DefaultSqlSession6. 进入到具体的sqlSession方法,比如selectList方法 1)方法内,根据id获取到MappedStatement对象(configuration对象里其实维护了一个map -> mappedStatements 全类名.方法名),包括sqlSource、resultMap等信息 2)然后调Executor对象执行(实现类BaseExecutor)(这里已经传了分页信息rowBounds)7. BaseExecutor调最后的doQuery()方法 1)交给jdbc的底层PreparedStatementHandler去处理8. PreparedStatementHandler真正执行sql 1) PreparedStatement ps = (PreparedStatement) statement 、ps.execute()9. 最后返回的PreparedStatement ps交给ResultSetHandler去处理 1)实现类DefaultResultSetHandler去把返回结果解析成List或者map

参考网址

注:文章是经过参考其他的文章然后自己整理出来的,有可能是小部分参考,也有可能是大部分参考,但绝对不是直接转载,觉得侵权了我会删,我只是把这个用于自己的笔记,顺便整理下知识的同时,能帮到一部分人。

ps : 有错误的还望各位大佬指正,小弟不胜感激

你可能感兴趣的文章
【虚拟机】虚拟化架构与系统部署(Windows系统安装)
查看>>
字节跳动安卓开发实习生面试分享
查看>>
好书分享之——《能力陷进》
查看>>
阅读笔记《c++ primer》
查看>>
阅读笔记《C++标准程序库》
查看>>
基于mirror driver的windows屏幕录像
查看>>
C语言8
查看>>
Qt实现简单延时
查看>>
qml有关矩形说明
查看>>
在qt中使用QSplitter设置初始比例setStretchFactor失效的解决方法
查看>>
repeater的使用
查看>>
qt msvc编译中文乱码解决
查看>>
qt实现点击出现窗口,点击其他任何地方窗口消失
查看>>
QML DropArea拖拉文件事件
查看>>
CORBA links
查看>>
读后感:&gt;
查看>>
ideas about sharing software
查看>>
different aspects for software
查看>>
To do list
查看>>
Study of Source code
查看>>