您的位置:首页 > 教育 > 锐评 > 苏州工业园区发布_手机在线画图工具_网络优化需要哪些知识_如何快速网络推广

苏州工业园区发布_手机在线画图工具_网络优化需要哪些知识_如何快速网络推广

2025/8/22 0:46:10 来源:https://blog.csdn.net/zp357252539/article/details/147545355  浏览:    关键词:苏州工业园区发布_手机在线画图工具_网络优化需要哪些知识_如何快速网络推广
苏州工业园区发布_手机在线画图工具_网络优化需要哪些知识_如何快速网络推广

以下是MyBatis缓存配置的完整示例,包含一级缓存、二级缓存、自定义缓存策略等核心场景,并附详细注释和总结表格:
在这里插入图片描述


1. 一级缓存(默认开启)

// 使用同一SqlSession执行两次查询,自动命中一级缓存
try (SqlSession session = sqlSessionFactory.openSession()) {UserMapper mapper = session.getMapper(UserMapper.class);User user1 = mapper.selectById(1);  // 第一次查询(数据库)User user2 = mapper.selectById(1);  // 第二次查询(缓存命中)System.out.println(user1 == user2); // 输出:true
}

2. 二级缓存配置(XML方式)

<!-- UserMapper.xml -->
<mapper namespace="com.example.mapper.UserMapper"><!-- 开启二级缓存 --><cache eviction="FIFO"         <!-- 缓存回收策略:先进先出 -->flushInterval="60000"   <!-- 缓存刷新间隔:60秒 -->size="512"              <!-- 缓存最大条目数 -->readOnly="false"/>      <!-- 是否只读(false允许对象修改) --><select id="selectById" resultType="User">SELECT * FROM user WHERE id = #{id}</select>
</mapper>

3. 二级缓存注解配置

// UserMapper.java
@Mapper
@CacheNamespace(implementation = EhcacheCache.class, // 使用第三方缓存(如Ehcache)eviction = CacheNamespaceEvictionPolicy.FIFO,flushInterval = 60000,size = 512,readWrite = true
)
public interface UserMapper {User selectById(Integer id);
}

4. 缓存对象序列化配置

// User实体类需要实现Serializable接口
public class User implements Serializable {private Integer id;private String name;private transient Integer age; // transient字段不参与序列化// 省略getter/setter
}

5. 缓存手动操作示例

// 清除指定对象缓存
sqlSession.clearCache(); // 清除一级缓存
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
mapper.selectById(1); 
sqlSession.commit(); // 触发二级缓存更新// 清除二级缓存
((org.apache.ibatis.session.Configuration)sqlSession.getConfiguration()).getCache("com.example.mapper.UserMapper").clear();

关键技术点总结表

场景配置方式适用情况核心注释
一级缓存默认开启(SqlSession级别)单次业务操作内多次查询不需要配置,关闭需调用sqlSession.clearCache()
二级缓存<cache>标签或@CacheNamespace跨SqlSession的全局缓存必须实现Serializable,需在Mapper配置中显式开启
缓存回收策略eviction="FIFO/LRU/SID"控制内存占用LRU(最近最少使用)最常用
缓存过期flushInterval="60000"定时刷新缓存毫秒单位,配合数据库数据变更频率设置
缓存容量size="512"控制内存使用根据业务数据量合理设置
缓存可写性readOnly="false"允许修改缓存对象readOnly为true时返回对象为不可变副本
第三方缓存implementation=EhcacheCache需要分布式缓存需引入对应依赖并配置缓存实现类

6. 核心配置注意事项:

  1. 序列化要求:被缓存的对象必须实现Serializable接口
  2. 事务边界:SqlSession关闭或提交(commit)会刷新二级缓存
  3. 并发控制readOnly="true"可避免并发修改问题
  4. 缓存失效:数据更新操作(insert/update/delete)会自动清除相关缓存
  5. 命名空间:二级缓存按Mapper命名空间隔离,需确保唯一性

7. 性能验证示例

// 验证二级缓存跨SqlSession命中
try (SqlSession session1 = sqlSessionFactory.openSession()) {UserMapper mapper1 = session1.getMapper(UserMapper.class);User user1 = mapper1.selectById(1); // 数据库查询
}try (SqlSession session2 = sqlSessionFactory.openSession()) {UserMapper mapper2 = session2.getMapper(UserMapper.class);User user2 = mapper2.selectById(1); // 二级缓存命中System.out.println(user1.equals(user2)); // 输出:true(值相等但对象不同)
}

需要进一步扩展场景(如条件缓存、自定义缓存实现)可补充说明。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com