java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Mybatis执行流程、缓存及面试题

Mybatis执行流程、缓存原理及相关面试题汇总

作者:爪洼ing

最近刚学完MyBatis,趁着大好机会,总结一下它的执行流程,面试也爱问这个,下面这篇文章主要给大家介绍了关于Mybatis执行流程、缓存原理及相关面试题的相关资料,需要的朋友可以参考下

一、Mybatis执行流程

具体分析Mybatis是如何操作数据库的!

、

1、定义我们的核心配置文件的路径,这个路径是从target/classes下开始找的!

 String config = "mybatis-config.xml" ;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WiYjb6lj-1642251251122)(Mybatis课堂笔记.assets/image-20220115155815228.png)]

2、读取这个config表示的文件

 InputStream inputStream= Resources.getResourceAsStream(config);

3、创建SqlSessionFactoryBuilder对象

SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();

4、创建SqlSessionFactory对象

SqlSessionFactory sessionFactory = builder.build(inputStream);

5、获取SqlSession对象,从SqlSessionFactory中获取

SqlSession sqlSession = sessionFactory.openSession();

6、【重点】执行我们的执行的的sql语句标识。sql文件中的namespace + sql标签的Id值

String sqlId = "com.sqx.dao.UserMapper.getUserById";

7、执行sql语句,通过sqlId找到语句,并执行!

List<Object> objects = sqlSession.selectList(sqlId);

8、关闭SqlSession

sqlSession.close();

总结

Myabtis启动的时候会加载mybatis-config.xml这个核心配置文件,得到要操作的数据库以及我们Mapper文件的的信息,然后将其以数据流的形式保存起来传给SqlSessionFactoryBuilder,创造出对应该数据库的SqlSessionFactory工厂,工厂生产SqlSession,这个SqlSession中包含了对该库的增删改查方法,我们需要通过namespace + sqlId来确定我们执行的是哪个sql,这一步操作可以通过SqlSeesion.getMapper()拿到接口,通过调用接口的方法(方法绑定了我们的sql,包含namespace + sqlId),执行对应的SQL语句!

二、Mybatis缓存

Mybatis缓存无论是一级缓存还是二级缓存都是本地缓存,都会占用JVM的内存,一旦Java停止缓存失效!

1、一级缓存

概述

如下是对一级缓存进行测试:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-cxzrwerK-1642251251124)(Mybatis课堂笔记.assets/image-20220115164223901.png)]

查看我们的测试结果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IBQtKdyL-1642251251125)(Mybatis课堂笔记.assets/image-20220115164344380.png)]

采用不同的SqlSession测试数据,进行如下修改!

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Vk9HjHYg-1642251251126)(Mybatis课堂笔记.assets/image-20220115164551824.png)]

我们再次查看测试结果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DpZ3eHA6-1642251251126)(Mybatis课堂笔记.assets/image-20220115164724002.png)]

得出结论我们的一级缓存只是在同一个SqlSession当中有效!

2、二级缓存

概述

二级缓存又称"全局缓存",是基于namespace级别的缓存,一个namespace对应一个二级缓存!

工作机制:

使用步骤 :

只需在需要使用缓存的namespace 中加入< cache/>即可

<!--在当前Mapper.xml中使用二级缓存,并配置相关参数-->
<cache  eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>

eviction :缓存的回收策略
	LRU(最长时间未使用)、LFU(访问次数最少)、FIFO(默认)、SOFT(软引用)、WEAK(弱引用)
flushInterval :  缓存刷新间隔
	缓存多久清空一次,默认是不会清空的,设置一个毫秒值
readOnly :是否只读
size :缓存存放多少元素

我们还可以通过配置实现自定义缓存

 <!--  开启mybatis的二级缓存,其本质还是我们mybatis帮我们实现了自身提供的缓存接口Cache,
也就是cache标签的type属性默认指定了缓存策略	-->

 <cache type=""/>    
 <!--本质上就是这种写法,我们可通该修改type来选择自定缓存策略-->
 <cache type="rg.apache.ibatis.cache.impl.PerpetualCache"/>  

3、缓存原理

如图所示

缓存执行流程

三、相关面试题

1、为什么说 Mybatis 是半自动ORM映射工具?它与全自动的区别在哪里?

什么是ORM

ORM(Object Relational Mapping),对象关系映射,是一种为了解决关系型数据库数据与简单 Java 对象(POJO)建里映射关系的技术。

为什么说 Mybatis 是半自动ORM映射工具?它与全自动的区别在哪里?

2、简述一下Mybatis的执行流程吧 ?

3、说一下Mybatis的优缺点 ?

优点

缺点

4、#{} 和 ${} 的区别是什么 ?

5、Mybatis的动态SQL有什么作用?执行原理是什么?有哪些常用标签?

总结

到此这篇关于Mybatis执行流程、缓存原理及相关面试题的文章就介绍到这了,更多相关Mybatis执行流程、缓存及面试题内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文