三 緩存 理解
1 一級緩存
session級別的緩存
一級緩存是SqlSession級別的緩存衬廷。在操作數(shù)據(jù)庫時需要構(gòu)造 sqlSession對象株茶,在對象中有一個(內(nèi)存區(qū)域)數(shù)據(jù)結(jié)構(gòu)(HashMap)用于存儲緩存數(shù)據(jù)蚂夕。不同的sqlSession之間的緩存數(shù)據(jù)區(qū)域(HashMap)是互相不影響的。
一級緩存的作用域是同一個SqlSession,在同一個sqlSession中兩次執(zhí)行相同的sql語句,第一次執(zhí)行完畢會將數(shù)據(jù)庫中查詢的數(shù)據(jù)寫到緩存(內(nèi)存)尼啡,第二次會從緩存中獲取數(shù)據(jù)將不再從數(shù)據(jù)庫查詢,從而提高查詢效率询微。當(dāng)一個sqlSession結(jié)束后該sqlSession中的一級緩存也就不存在了崖瞭。Mybatis默認(rèn)開啟一級緩存。
如果沒有啟動事務(wù)撑毛,mybatis的一級緩存在spring中是沒有作用的.
2 二級緩存
mapper級別的緩存
二級緩存是mapper級別的緩存书聚,多個SqlSession去操作同一個Mapper的sql語句,多個SqlSession去操作數(shù)據(jù)庫得到數(shù)據(jù)會存在二級緩存區(qū)域代态,多個SqlSession可以共用二級緩存寺惫,二級緩存是跨SqlSession的疹吃。
二級緩存是多個SqlSession共享的蹦疑,其作用域是mapper的同一個namespace,不同的sqlSession兩次執(zhí)行相同namespace下的sql語句且向sql中傳遞參數(shù)也相同即最終執(zhí)行相同的sql語句萨驶,第一次執(zhí)行完畢會將數(shù)據(jù)庫中查詢的數(shù)據(jù)寫到緩存(內(nèi)存)歉摧,第二次會從緩存中獲取數(shù)據(jù)將不再從數(shù)據(jù)庫查詢,從而提高查詢效率腔呜。Mybatis默認(rèn)沒有開啟二級緩存需要在setting全局參數(shù)中配置開啟二級緩存叁温。
注意:相關(guān)實體類需要實現(xiàn)Serializable接口,否則關(guān)閉session時候報錯
主配置文件:
<setting name="cacheEnabled" value="true"/>
映射配置文件
<!-- eviction 緩存策略
flushInterval 刷新間隔核畴,單位毫秒
size 引用數(shù)目
readOnly 是否只讀
-->
<cache
eviction="FIFO"
flushInterval="10000"
size="1000"
readOnly="true"
></cache>
flushInterval:
刷新間隔,可以被設(shè)置為任意的正整數(shù)膝但,單位毫秒。默認(rèn)情況是不設(shè)置谤草,也就是沒有刷新間隔跟束。
Size:
引用數(shù)目,可以被設(shè)置為任意正整數(shù)丑孩,緩存的對象數(shù)目和你運行環(huán)境的可用內(nèi)存資源數(shù)目冀宴。默認(rèn)值是1024。
readOnly:
是否只讀温学,屬性可以被設(shè)置為true或false略贮。只讀的緩存會給所有調(diào)用者返回緩存對象的相同實例,默認(rèn)是false。
Eviction:
收回策略逃延,
LRU – 最近最少使用的:移除最長時間不被使用的對象览妖。
FIFO – 先進(jìn)先出:按對象進(jìn)入緩存的順序來移除它們。