我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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、一级缓存

概述

  • 一级缓存保存在我们的SqlSession当中
  • 只要是同一个SqlSesisson(与数据库建立的会话)就会使用同一个缓存
  • 一级缓存是我们Mybatis默认开启的!

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

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(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对应一个二级缓存!

工作机制:

  • 一个会话查询一条数据,这个数据会被放在一级缓存当中
  • 当我们会话关闭的时候,会把这个数据从1级缓存迁入二级缓存当中,新的会话就可以在二级缓存当中找到这个数据!
  • 不同的会话查询不同的namespace的时候,会将不同namespace中的数据缓存到自己对应的缓存(map)中!

使用步骤 :

只需在需要使用缓存的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、缓存原理

如图所示

缓存执行流程

  • 当我们的sql执行的时候,先去二级缓存namespace中查看是否存在缓存,
  • 然后如果二级缓存不存在,查看当前sqlSession中一级缓存中是否存在,
  • 最后一、二级缓存中都不存在的话那么就去数据库查询,
  • 接着会将查询出来的结果保存在我们的一级缓存当中,
  • 当前会话(SqlSession)结束,就会将一级缓存中的数据,同步到我们的二级缓存

三、相关面试题

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

什么是ORM

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

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

  • 首先,像 Hibernate、JPA 这种属于全自动 ORM 映射工具,使用 Hibernate 查询关联对象或者关联集合对象时,可以根据对象关系模型直接获取,所以它是全自动的。
  • 而 Mybatis 在查询关联对象或关联集合对象时,需要手动编写 sql 来完成,所以,称之为半自动 ORM 映射工具。
  • 换句话来解释就是说 MyBatis 是 半自动 ORM 最主要的一个原因是,它需要在 XML 或者注解里通过手动或插件生成 SQL,才能完成 SQL 执行结果与对象映射绑定。

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

  • MyBatis 是以一个 SqlSessionFactory 实例为核心,SqlSessionFactory 的实例可以通过 SqlSessionFactoryBuilder 获得。
  • SqlSessionFactoryBuilder 可以从 XML 配置文件或一个预先配置的 Configuration 实例来构建出 SqlSessionFactory 实例。
  • SqlSessionFactory 实例工厂可以生产 SqlSession ,它里面提供了在数据库执行 SQL 命令所需的所有方法。

3、说一下Mybatis的优缺点 ?

优点

  • 基于SQL语句编写、相当灵活,SQL写在XML文件当中,解除了sql与程序代码的耦合,便于统一管理
  • 消除了JDBC的冗余代码、能够与Spring很好的集成

缺点

  • SQL语句的编写工作量大,尤其是字段多,关联表多的情况下,对开发人员的SQL语句功底有一定的要求
  • SQL语句依赖数据库,导致数据库移植性差,不能随意更换数据库

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

  • #{} 是占位符,预编译处理,${}是拼接符,字符串替换,没有预编译处理
  • mybatis在处理#{}的时候,#{} 传入的参数是字符串,会将SQL中的#{} 替换为?调用PreparedStatement的Set方法赋值
  • myabtsi在处理的 时 候 , 就 是 原 值 传 入 , 就 是 把 {}的时候,就是原值传入,就是把的时候,就是原值传入,就是把{}替换为传来的值
  • #{}通过编译预处理可以有效地防止SQL注入问题,提高系统的安全性,${}则不能防止SQL注入

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

  • mybatis动态sql可以在xml映射文件内,以标签的形式编写动态sql
  • 执行原理:根据参数表达式的值完成逻辑判断,并且动态拼接sql
  • mybatis提供9种动态sql的标签:trim、where、set、foreach、if、choose、when、otherwise、bind

总结

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录