一級(jí)緩存

一級(jí)緩存的機(jī)制

首先,一級(jí)緩存是sqlSession級(jí)別的,也就是在一個(gè)sqlSession中如果進(jìn)行了多次重復(fù)的sql查詢操作,實(shí)際上除了第一次后面都是從緩存中獲取的(這里只講解一級(jí)緩存?默認(rèn)二級(jí)緩存關(guān)閉).當(dāng)然如果我們對(duì)數(shù)據(jù)進(jìn)行了增刪改操作以及事務(wù)提交關(guān)閉就會(huì)刷新緩存,一級(jí)緩存的數(shù)據(jù)結(jié)構(gòu)是一個(gè)hashMap.下面演示一下效果


無(wú)更新操作
結(jié)果


新增更新操作


結(jié)果展示

我們可以看出三點(diǎn):

1)?連續(xù)兩次查詢同一數(shù)據(jù)第一次會(huì)去數(shù)據(jù)庫(kù)中查詢,后面會(huì)直接從緩存中取值.

2)從緩存中取值的對(duì)象是同一個(gè)對(duì)象

3)進(jìn)行更新操作后?會(huì)刷新緩存?從數(shù)據(jù)庫(kù)從新取值


一級(jí)緩存流程

源碼分析

首先我們帶著問(wèn)題進(jìn)行分析

一級(jí)緩存到底是什么?一級(jí)緩存什么時(shí)候被創(chuàng)建、一級(jí)緩存的工作流程是怎樣的?

查詢流程剖析

mybatis中所有的查詢基本都是走Sqlsession.selectList方法?所以我們只需要找其中有關(guān)緩存的方法即可

緩存流程

源碼分析

首先一級(jí)緩存的?數(shù)據(jù)結(jié)構(gòu)是hashMap證明

我們可以直接從execute.query中查看

execute.query緩存操作
查詢后插入一級(jí)緩存

從源碼中還可以看出當(dāng)LocalCacheScope屬性設(shè)置為STATEMENT時(shí)候查詢也是會(huì)清空緩存的

LocalCacheScope配置相關(guān)

進(jìn)行更新操作時(shí)候?緩存也會(huì)清空


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • MyBatis將數(shù)據(jù)緩存設(shè)計(jì)成兩級(jí)結(jié)構(gòu),分為一級(jí)緩存、二級(jí)緩存:一級(jí)緩存是Session會(huì)話級(jí)別的緩存:表示一次數(shù)...
    ChinaXieShuai閱讀 1,699評(píng)論 0 9
  • MyBatis是一個(gè)簡(jiǎn)單,小巧但功能非常強(qiáng)大的ORM開(kāi)源框架,它的功能強(qiáng)大也體現(xiàn)在它的緩存機(jī)制上。MyBatis提...
    匠丶閱讀 701評(píng)論 0 5
  • MyBatis簡(jiǎn)介 MyBatis 是一款優(yōu)秀的持久層框架,它支持定制化 SQL、存儲(chǔ)過(guò)程以及高級(jí)映射。MyBat...
    意識(shí)流丶閱讀 9,727評(píng)論 1 23
  • 久違的晴天,家長(zhǎng)會(huì)。 家長(zhǎng)大會(huì)開(kāi)好到教室時(shí),離放學(xué)已經(jīng)沒(méi)多少時(shí)間了。班主任說(shuō)已經(jīng)安排了三個(gè)家長(zhǎng)分享經(jīng)驗(yàn)。 放學(xué)鈴聲...
    飄雪兒5閱讀 7,819評(píng)論 16 22
  • 今天感恩節(jié)哎,感謝一直在我身邊的親朋好友。感恩相遇!感恩不離不棄。 中午開(kāi)了第一次的黨會(huì),身份的轉(zhuǎn)變要...
    余生動(dòng)聽(tīng)閱讀 10,852評(píng)論 0 11

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