文章目录
一、什么是Mybatis 缓存
缓存是一般的 ORM 框架都会提供的功能,目的就是提升查询的效率和减少数据库的压力,缓存的重要性是不言而喻的。Mybatis 会将相同查询条件的 SQL 语句的查询结果存储在内存或者某种缓存介质当中,当下次遇到相同的查询 SQL 时候不在执行该 SQL,而是直接从缓存中获取结果,减少服务器的压力,尤其是在查询越多、缓存命中率越高的情况下,使用缓存对性能的提高更明显。
MyBatis 缓存方式分为一级缓存和二级缓存,同时也可配置关于缓存设置。
一级缓存是将结果缓存在 SqlSession 对象中,二级缓存是存储在 SqlSessionFactory 对象中。默认情况下,MyBatis 开启一级缓存,没有开启二级缓存。
当数据量大的时候可以借助一些第三方缓存技术来协助保存 Mybatis 的二级缓存数据。
二、一级缓存的使用
一级缓存也叫本地缓存,MyBatis 的一级缓存是在会话(SqlSession)层面进行缓存的。MyBatis 的一级缓存是默认开启的,不需要任何的配置。
1、一级缓存的生命周期
2、如何判断两次查询是完全相同的查询
3、测试一级缓存
public class SelectUsersByIdCacheOneTest {
public static void main(String[] args) {
SqlSession sqlSession = MybatisUtils.getSqlSession();
UsersMapper usersMapper = sqlSession.getMapper(UsersMapper.class);
Users users = usersMapper.selectUsersById(1);
Users users1 = usersMapper.selectUsersById(1);
System.out.println(users);
System.out.println(users1);
}
}
public class SelectUsersByIdCacheOneTest {
public static void main(String[] args) {
SqlSession sqlSession = MybatisUtils.getSqlSession();
UsersMapper usersMapper = sqlSession.getMapper(UsersMapper.class);
Users users = usersMapper.selectUsersById(1);
sqlSession.clearCache();
Users users1 = usersMapper.selectUsersById(1);
System.out.println(users);
System.out.println(users1);
}
}
三、二级缓存的使用
MyBatis 的二级缓存是 Application 级别的缓存,它可以提高对数据库查询的效率,以提高应用的性能。二级缓存是 SqlSessionFactory 上的缓存,可以是由一个 SqlSessionFactory 创建的不同的 SqlSession 之间共享缓存数据。默认并不开启。
SqlSession 在执行 commit()或者 close()的时候将数据放入到二级缓存。
Sqlsession 共享二级缓存:
1、二级缓存的配置方式
二级缓存的开启需要进行配置,实现二级缓存的时候,MyBatis 要求缓存的 POJO 必须是可序列化的, 也就是要求实现 Serializable 接口。在映射配置文件中配置就可以开启缓存了。
2、二级缓存特点
3、cache 标签的可选属性
四、测试二级缓存
1、 配置 cacheEnabled
在 mybatis-config.xml 文件中的标签配置开启二级缓存。cacheEnabled 的默认值就是 true,所以这步的设置可以省略。
<settings>
<setting name="cacheEnabled" value="true"/>
</settings>
2、 在映射配置文件中添加
<mapper namespace="com.bjsxt.mapper.UsersMapper">
<cache/>
</mapper>
3、 JavaBean 对象必须实现序列化接口
public class Users implements Serializable{}
4、创建测试类
public class SelectUsersByIdCacheTwoTest {
public static void main(String[] args) {
SqlSession sqlSession = MybatisUtils.getSqlSession();
UsersMapper usersMapper = sqlSession.getMapper(UsersMapper.class);
Users users = usersMapper.selectUsersById(1);
System.out.println(users);
MybatisUtils.closeSqlSession();
System.out.println("------------------------------------------------------------");
SqlSession sqlSession1 = MybatisUtils.getSqlSession();
UsersMapper usersMapper1 = sqlSession1.getMapper(UsersMapper.class);
Users users1 = usersMapper1.selectUsersById(1);
System.out.println(users1);
}
}
5、测试结果
不同的Sqlsession第二次查询时直接从缓存中拿取数据