MyBatis缓存

本文详细介绍了MyBatis的一级缓存和二级缓存。一级缓存默认开启,基于SqlSession,相同参数的查询只执行一次SQL。二级缓存则为namespace级别的,跨SqlSession,需要额外配置并确保实体类实现Serializable接口。缓存的清除和更新策略也在文中提及。
摘要由CSDN通过智能技术生成

为什么使用缓存?

经常查询一些不经常发生变化的数据,使用缓存来提高查询效率。

Mybatis中缓存分为一级缓存,二级缓存。

1.一级缓存

一级缓存是SqlSession级别的缓存,是默认开启的。

在参数和SQL语句完全相同的情况下,

使用SqlSession对象调用一个Mapper方法,

InputStream resource = Resources.getResourceAsStream("SqlMapConfig.xml");
        SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(resource);
        SqlSession sqlSession = factory.openSession();

        UserMapper mapper = sqlSession.getMapper(UserMapper.class);

然后通过Mapper方法调用你编写的查询方法,不论你调用几次查询方法

User userById = mapper.findUserById(1);
        System.out.println("====第一次查询====:" + userById);

        User userById1 = mapper.findUserById(1);
        System.out.println("====第二次查询====:" + userById1);

程序只会执行一次SQL(即向数据库发送一次SQL请求),因为在使用SqlSession进行第一次查询后,Mybatis就会将其放入缓存中,当你后续再调用查询方法时,如果没有声明需要刷新缓存没有超时的情况下,SqlSession都会取出缓存的数据,而不会再次发送SQL请求到数据库,这样就提高了效率。

一级缓存是SqlSession范围的缓存,执行SqlSession的增、删、改操作,或者调用clearCache()、commit()、close()方法,都会清空缓存

清除缓存的方法

1.

//调用sqlSession清除缓存的方法 
	sqlSession.clearCache();

2.

<!-- 每次查询时,都会清除缓存 --> 
< select flushCache="true"></select>

2.二级缓存

二级缓存是namspace级别(跨sqlSession)的缓存,是默认不开启的

二级缓存的开启需要进行配置,实现二级缓存的时候,MyBatis要求返回的POJO必须是可序列化的。
也就是要求实现Serializable接口,配置方法很简单,

SqlMapConfig.xml

<!--        因为cacheEnabled的取值默认就为true,所以这一步可以省略不配置。
		    为true代表开启二级缓存;为false代表不开启二级缓存。
-->
        <setting name="cacheEnabled" value="true"/>

UserMapper.xml

<!--    开启二级缓存-->
    <cache/>
<!--    查询所有订单 及对应的用户信息-->
<!--    在标签中设置useCache=“true” 表示当前statement 要使用二级缓存
        如果不用 可以设置为false
-->
    <select id="findUserById" parameterType="int" resultType="com.qiku.popo.User" useCache="true">
        select * from  user where id = #{id}
    </select>

还有你的实体类中要继承

Serializable 接口
public class User implements Serializable {
 。。。。。。。
}

在你测试代码中执行完代码后,要加入下面两句中的任意一句

sqlSession1.close();//将结果存入二级缓存
sqlSession1.commit();

除了第一个方法可以省略外,剩下一定要写

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值