mybatis的一级缓存和二级缓存的理解

mybatis缓存:
使用缓存,是为了避免频繁的与数据库进行交互,尤其是在查询越多的情况下,缓存命中率越高的情况下,使用缓存对性能的提高更明显
mybatis支持缓存,分为一级缓存和二级缓存,在默认的情况下,只开启了一级缓存;

一级缓存:
同一个sqlsession对象,在参数和SQL完全一样的情况下,只执行一次SQL语句(前提是缓存没有过期)
在同一个sqlsession中,执行相同的查询,首先去缓存中是否有我们查询的信息,如果没有,从数据库进行查询,并将查询到的信息保存到一级缓存中,当第二次在查询相同的操作时,就去缓存中拿到我们刚才查询的数据,并返回给用户
如果中间sqlsession执行commit操作(执行插入\更新\删除),则会清空sqlsession中的一级缓存,这样做的目的为了让缓存中存储的是最新的信息,避免脏读;

二级缓存:
二级缓存存在于 SqlSessionFactory 生命周期中,不管是不是相同的session,只要mapper的namespace相同,可能共享缓存,要求:如果开启了二级缓存,那么在关闭sqlsession后(close),才会把该sqlsession一级缓存中的数据添加到namespace的二级缓存中。

总结:
一级缓存时执行commit,close,增删改等操作,就会清空当前的一级缓存;当对SqlSession执行更新操作(update、delete、insert)后并执行commit时,不仅清空其自身的一级缓存(执行更新操作的效果),也清空二级缓存(执行commit()的效果)。

开启了二级缓存后,还需要将要缓存的pojo实现Serializable接口,为了将缓存数据取出执行反序列化操作,因为二级缓存数据存储介质多种多样,不一定只存在内存中,有可能存在硬盘中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值