Mybatis执行流程、缓存原理以及相关面试题(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/>即可

eviction :缓存的回收策略

LRU(最长时间未使用)、LFU(访问次数最少)、FIFO(默认)、SOFT(软引用)、WEAK(弱引用)

flushInterval : 缓存刷新间隔

缓存多久清空一次,默认是不会清空的,设置一个毫秒值

readOnly :是否只读

size :缓存存放多少元素

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

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

最后

现在正是金三银四的春招高潮,前阵子小编一直在搭建自己的网站,并整理了全套的**【一线互联网大厂Java核心面试题库+解析】:包括Java基础、异常、集合、并发编程、JVM、Spring全家桶、MyBatis、Redis、数据库、中间件MQ、Dubbo、Linux、Tomcat、ZooKeeper、Netty等等**

image

sql

  • 执行原理:根据参数表达式的值完成逻辑判断,并且动态拼接sql

最后

现在正是金三银四的春招高潮,前阵子小编一直在搭建自己的网站,并整理了全套的**【一线互联网大厂Java核心面试题库+解析】:包括Java基础、异常、集合、并发编程、JVM、Spring全家桶、MyBatis、Redis、数据库、中间件MQ、Dubbo、Linux、Tomcat、ZooKeeper、Netty等等**

[外链图片转存中…(img-SvJ9wY7X-1714420800070)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

  • 21
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值