mybatis緩存

mybatis有兩級緩存

一級緩存(默認(rèn)), session緩存, 基于PerpetualCache 的 HashMap本地緩存,在session flush或者close的時(shí)候?qū)⑾?/p>

 SqlSession sqlSession = MyBatisUtil.getSqlSessionFactory().openSession();  //打開
..
..
..
sqlSession .close();    //關(guān)閉

二級緩存,同樣也是基于PerpetualCache 的 HashMap本地緩存,不同在于其存儲(chǔ)作用域?yàn)?Mapper(Namespace),并且可自定義存儲(chǔ)源,如 Ehcache。

<mapper namespace="me.gacl.mapping.userMapper">
<!-- 開啟二級緩存 -->
<cache/>
 
image.png

如果實(shí)體類不實(shí)現(xiàn)可序列化接口,使用二級緩存,那么會(huì)報(bào)下列異常:
Exception in thread "main" org.apache.ibatis.cache.CacheException: Error serializing object. Cause: java.io.NotSerializableException: Teacher................
所以在二級緩存的時(shí)候?qū)嶓w一定要是實(shí)現(xiàn)Serializable

public class Teacher implements Serializable
{
}
注意:使用兩個(gè)不同的SqlSession對象去執(zhí)行相同查詢條件的查詢,第二次查詢時(shí)不會(huì)再發(fā)送SQL語句,而是直接從緩存中取出數(shù)據(jù)
對于緩存數(shù)據(jù)更新機(jī)制,當(dāng)某一個(gè)作用域(一級緩存Session/二級緩存Namespaces)的進(jìn)行了 C/U/D 操作后,默認(rèn)該作用域下所有 select 中的緩存將被clear。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容