一級(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.下面演示一下效果




我們可以看出三點(diǎn):
1)?連續(xù)兩次查詢同一數(shù)據(jù)第一次會(huì)去數(shù)據(jù)庫(kù)中查詢,后面會(huì)直接從緩存中取值.
2)從緩存中取值的對(duì)象是同一個(gè)對(duì)象
3)進(jìn)行更新操作后?會(huì)刷新緩存?從數(shù)據(jù)庫(kù)從新取值

源碼分析
首先我們帶著問(wèn)題進(jìn)行分析
一級(jí)緩存到底是什么?一級(jí)緩存什么時(shí)候被創(chuàng)建、一級(jí)緩存的工作流程是怎樣的?
查詢流程剖析
mybatis中所有的查詢基本都是走Sqlsession.selectList方法?所以我們只需要找其中有關(guān)緩存的方法即可

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

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


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

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