Mybatis缓存

将从数据库中查询出来的数据缓存起来,而不从数据库查询,减少了数据库的操作,提高了数据处理性能。
缓存介质:内存、磁盘,从缓存中取数据,

1、一级缓存

Mybatis默认提供一级缓存,缓存范围是一个sqlSession。

在同一个SqlSession中,两次执行相同的sql查询,第二次不再从数据库查询。

如果该SqlSession执行commit()提交,清除缓存。

原理:
一级缓存采用Hashmap存储,mybatis执行查询时,从缓存中查询,如果缓存中没有从数据库查询。

2、二级缓存

二级缓存范围是跨SqlSession的,范围是mapper的namespace,相同的namespace使用一个二级缓存。

需要进行参数配置让mybatis支持二级缓存。

//1、在核心配置文件SqlMapConfig.xml中加入,表示打开二级缓存开关
<setting name="cacheEnabled" value="true"/>
//在mapper.xml中配置是否打开该mapper的二级缓存。
<mapper namespace="cn.com.UserMapper">
    <cache/>
</mapper>

useCache=”false”,表示该statement不再进行二级缓存:

<select id="findUserById" parameterType="int" resultType="user" useCache="false">
    select * from User where id = #{id}
</select>

flushCache=”false”,执行更新操作后,不刷新二级缓存:

<update id="updateUser" parameterType="int" resultType="user" flushCache="false">
    select * from User where id = #{id}
</update>

如果二缓存开启,首先从二级缓存查询数据,若没有,则从一级缓存查询数据,若仍然没有,则查询数据库。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值