Mybatis学习笔记03_缓存机制

Mybatis的缓存分为一级缓存和二级缓存

像大多数的持久化框架一样,Mybatis 也提供了缓存策略,通过缓存策略来减少数据库的查询次数,从而提高性能。

一级缓存:

一级缓存是 SqlSession 级别的缓存,只要 SqlSession 没有 flush 或 close,它就存在。(flush --> 对数据的增删改操作)

一级缓存是不能关闭的,但可以设置flushCache=true强制清除缓存或更改localCacheScope=STATEMENT,这样每次都会查数据库,当然也可以手动调用session.clearCache清除

  • 什么是SqlSession?(下面初始化Mybatis框架的第四步中得到的就是SQLSession)
@Before//在测试方法执行之前执行
public void init()throws Exception {
	//1.读取配置文件
	in = Resources.getResourceAsStream("SqlMapConfig.xml");
	//2.创建构建者对象
	SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
	//3.创建 SqlSession 工厂对象
	factory = builder.build(in);
	//4.创建 SqlSession 对象
	session = factory.openSession();
	//5.创建 Dao 的代理对象
	userDao = session.getMapper(IUserDao.class);
}
  • 再问那一级缓存又是如何去使用呢?

      (假如现在我们需要两次查询一个同一个用户信息)
    
@Test
public void testQuery(){
	User user = userDao.findById(1);
	System.out.println("第一次查询的用户:"+user);
	User user2 = userDao.findById(1);
	System.out.println("第二次查询用户:"+user2);
	System.out.println(user == user2);
}
	(控制台输出是这样的)

在这里插入图片描述

我们可以发现,虽然在上面的代码中我们查询了两次,但最后只执行了一次数据库操作,这就是 Mybatis 提供给我们的一级缓存在起作用了。因为一级缓存的存在,导致第二次查询 id 为 1 的记录时,并没有发出 sql 语句从数据库中查询数据,而是从一级缓存中查询。


二级缓存

二级缓存是 mapper 映射级别的缓存,多个 SqlSession 去操作同一个 Mapper 映射的 sql 语句,多个SqlSession 可以共用二级缓存,二级缓存是跨 SqlSession 的。

 @Test
 public void testSecondLevelCache(){
	 SqlSession sqlSession1 = factory.openSession();
	 IUserDao dao1 = sqlSession1.getMapper(IUserDao.class);
	 User user1 = dao1.findById(1);
	 System.out.println(user1);
	 sqlSession1.close();//一级缓存消失
	 
	 SqlSession sqlSession2 = factory.openSession();
	 IUserDao dao2 = sqlSession2.getMapper(IUserDao.class);
	 User user2 = dao2.findById(1);
	 System.out.println(user2);
 }

经过上面的测试,我们发现控制台输出同上:在执行第一次查询后,我们关闭了一级缓存,再去执行第二次查询时,我们发现并没有对数据库发出 sql 语句,所以此时的数据就只能是来自于我们所说的二级缓存。

  • 在持久层接口中使用注解配置二级缓存
@CacheNamespace(blocking=true)//mybatis 基于注解方式实现配置二级缓存
public interface IUserDao { ... }

还有一点要注意的:
当我们在使用二级缓存时,所缓存的类一定要实现 java.io.Serializable 接口,这种就可以使用序列化方式来保存对象。

public class User implements Serializable {
	private Integer id;
	private String username;
	...
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值