系列文章目录
1、mybatis简介及数据库连接池
2、mybatis简单使用
3、mybatis中selectOne的使用
4、mybatis中resultMap结果集的使用
5、mybatis实用教程之XML实现动态sql
6、Mybatis使用注解实现复杂动态SQL
前言
MyBatis 提供了两级缓存机制:一级缓存(本地缓存)和二级缓存(全局缓存)。一级缓存是默认开启的,它是基于 SqlSession 级别的缓存,同一个 SqlSession 内相同的查询会被缓存起来;二级缓存是跨 SqlSession 的缓存,它可以被多个 SqlSession 共享,需要在 Mapper 文件中显式配置启用。
一级缓存对于减少数据库访问,提高性能有一定帮助,但是仅限于同一个 SqlSession 内。而二级缓存则是跨 SqlSession 的,可以跨 Session 共享缓存结果,适用于跨 Session 但是相同查询的情景。
1、配置二级缓存
<configuration>
<settings>
<setting name="cacheEnabled" value="true"/>
</settings>
</configuration>
<mapper namespace="com.example.mapper.UserMapper">
<cache/>
<!-- 其他 SQL 映射配置 -->
</mapper>
2、使用场景:
假设有一个用户信息查询的场景,多个不同的用户查询请求频繁访问相同的数据。
// UserMapper.java
public interface UserMapper {
List<User> getAllUsers();
}
<!-- UserMapper.xml -->
<mapper namespace="com.example.mapper.UserMapper">
<cache/>
<select id="getAllUsers" resultType="User">
SELECT * FROM users
</select>
</mapper>
// 使用代码
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(Resources.getResourceAsReader("mybatis-config.xml"));
try (SqlSession sqlSession = factory.openSession()) {
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
// 第一次查询
List<User> users1 = userMapper.getAllUsers();
// 再次查询相同数据
List<User> users2 = userMapper.getAllUsers();
}
3、注意事项:
这个示例展示了 MyBatis 的二级缓存配置和使用场景,但在实际应用中,需要根据业务情况和性能调优来决定是否使用缓存,并针对具体情况进行调整。
原文地址:https://blog.csdn.net/weixin_45915647/article/details/134754213
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_32530.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!