MyBatis相关面试题

提示:MyBatis相关面试题,持续更新中

文章目录


1、MyBatis框架是如何实现分页的?

java 复制代码
分页分为两种:
	逻辑分页:将所有数据查询出来,再在内存中进行分页处理;
	物理分页:直接在数据库中进行分页;
	
具体实现:
	1、自己写SQL进行分页;(物理分页)
	2、使用拦截器进行分页;(物理分页)
	3、使用PageHelper进行分页;(物理分页)
	4、使用RowBounds进行分页;(逻辑分页)
	

2、说一说MyBatis框架里面的缓存机制是怎么回事?

MyBatis中有两级缓存:一级缓存 和 二级缓存;

(1)一级缓存

java 复制代码
1、一级缓存是SqlSession级别的缓存, 通过同一个SqlSession查询的数据会被缓存,下次查询相同的数据,就会从缓存中直接获取,
	不会再从数据库查询;
	
2、一级缓存是默认开启的,是不能关闭的,但可以调用SqlSession的clearCache()方法清理缓存;

3、不同SqlSession之间的缓存数据是隔离的,即一个SqlSession中的缓存数据在另一个SqlSession中是读取不到的;

4、一级缓存的作用范围可以配置两种:
	local-cache-scope: statement(配置后,会清理缓存,相当于缓存失效)
	local-cache-scope: session(默认)

--------------------------------------------------------------------------------------------------------------------

一级缓存失效的几种情况
	1、不同的SqlSession对应不同的一级缓存;
	2、同一个SqlSession但是查询条件不同;
	3、同一个SqlSession两次查询期间执行了任何一次增删改操作;
	4、同一个SqlSession两次查询期间手动清空了缓存;

--------------------------------------------------------------------------------------------------------------------

注:以下代码,若不开启事务,每一次的goodsDao.queryByPage()都是新的sqlsession不会存在一级缓存,只有开启事务后,才会有一级缓存
    @Resource
    private GoodsDao goodsDao;

    //@Transactional
    @Override
    public List<Goods> queryByPage(Integer startRow, Integer pageSize) {
        List<Goods> list1 = goodsDao.queryByPage(startRow, pageSize);
        System.out.println("查詢1:" + list1 + "\n");

        List<Goods> list2 = goodsDao.queryByPage(startRow, pageSize);
        System.out.println("查詢2:" + list2 + "\n");
        return list2;
    }

(2)二级缓存

二级缓存在SqlSession提交或关闭后才生效;

java 复制代码
二级缓存默认是关闭的,开启二级缓存,需要同时有如下两项:
	application.yml  
		mybatis:
		  configuration:
		    cache-enabled: true
		    
	Mapper.xml
	<cache/>
	
二级缓存是跨SqlSession的,多个SqlSession可以共用同一个二级缓存;

二级缓存是mapper级别的缓存,根据mapper的namespace区分,两个mapper的namespace相同,
	则这两个mapper执行sql查询到的数据将缓存到相同的二级缓存区域中;
	
使用二级缓存的POJO类要实现Serializable接口;
相关推荐
cmpxr_12 分钟前
【C】局部变量和全局变量及同名情况
c语言·开发语言
小碗羊肉1 小时前
【从零开始学Java | 第三十一篇下】Stream流
java·开发语言
❀͜͡傀儡师1 小时前
Spring AI Alibaba vs. AgentScope:两个阿里AI框架,如何选择?
java·人工智能·spring
aq55356001 小时前
Laravel10.x重磅升级,新特性一览
android·java·开发语言
一 乐2 小时前
酒店预订|基于springboot + vue酒店预订系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·酒店预订系统
报错小能手2 小时前
ios开发方向——swift错误处理:do/try/catch、Result、throws
开发语言·学习·ios·swift
Moe4882 小时前
Spring AI Advisors:从链式增强到递归顾问
java·后端
敖正炀2 小时前
ReentrantReadWriteLock、ReentrantLock、synchronized 对比
java
网域小星球2 小时前
C 语言从 0 入门(十七)|结构体指针 + 动态内存 + 文件综合实战
c语言·开发语言·文件操作·结构体指针·动态内存·综合项目
cike_y2 小时前
Java反序列化漏洞-Shiro721流程分析
java·反序列化·shiro框架