ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

mybatis-测试二级缓存

2022-01-15 10:31:45  阅读:137  来源: 互联网

标签:UserMapper sqlSession System println 二级缓存 测试 mybatis out


1.在mybatis-config.xml中开启二级缓存

<setting name="cacheEnabled" value="true"/>

2.在Mapper.xml中需要设置二级缓存的namespace中添加cache标签

<cache/>

2.1也可以在cache标签中对二级缓存进行配置

<cache
  eviction="FIFO"
  flushInterval="60000"
  size="512"
  readOnly="true"/>

这个更高级的配置创建了一个 FIFO 缓存,每隔 60 秒刷新,最多可以存储结果对象或列表的 512 个引用,而且返回的对象被认为是只读的,因此对它们进行修改可能会在不同线程中的调用者 产生冲突。

3.测试

3.1测试

@Test
public void test(){
    SqlSession sqlSession = MybatisUtils.getSqlSession();
    UserMapper mapper = sqlSession.getMapper(UserMapper.class);
    UserMapper mapper1 = sqlSession.getMapper(UserMapper.class);
    User user = mapper.queryUserById(1);
    User user2 = mapper1.queryUserById(1);
    System.out.println(user);
    System.out.println("==================================================");
    System.out.println(user2);
    System.out.println(user == user2);
    sqlSession.close();
}

3.2执行异常

原因:写入的对象没有序列化,实例类需要实现Serializable接口

@Data
@AllArgsConstructor
@NoArgsConstructor
public class User implements Serializable {
    private int id;
    private String name;
    private String pwd;
}

3.3再次执行结果分析

只查询了一次数据库,并且两次查询返回的对象相同,说明第二次是在缓存中查询的,说明二级缓存的作用域大于一级缓存,即便是两个不同的sqlSession缓存也能生效

标签:UserMapper,sqlSession,System,println,二级缓存,测试,mybatis,out
来源: https://www.cnblogs.com/lv1024/p/15806243.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有