使用缓存可以使应用更快的获取数据,避免频繁的数据库交互,Mybatis提供了非常强大的查询缓存特性,一般提到的Mybatis缓存都是指二级缓存。一级缓存(本地缓存)默认会启用,并且不能控制,因此很少会提到。
一级缓存
通过以下案例查看Mybatis一级缓存如何起作用
测试代码如下
package tk.mybatis.simple.mapper;
import org.apache.ibatis.session.SqlSession;
import org.junit.Assert;
import org.junit.Test;
import tk.mybatis.simple.model.SysUser;
/**
* 缓存测试类
* @author Administrator
*
*/
public class CacheTest extends BaseMapperTest{
//测试以及缓存
@Test
public void testL1Cache(){
SqlSession sqlSession = getSqlSession();
SysUser user1 = null;
try{
//获取UserMapper接口
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
//调用selectById方法 查询id = 1的用户
user1 = userMapper.selectById(1L);
//对当前获取的对象重新赋值
user1.setUserName("New Name");
//再次查询获取id相同的用户
SysUser user2 = userMapper.selectById(1L);
//虽然没有更新数据库,但是这个用户名和user1重新赋值的名字相同
Assert.assertEqua