1.什么是查詢(xún)緩存

mybatis提供查詢(xún)緩存,用于減輕數(shù)據(jù)庫(kù)壓力,提高數(shù)據(jù)庫(kù)性能。

mybatis提供一級(jí)緩存和二級(jí)緩存。

photoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動(dòng)軟件開(kāi)發(fā)培訓(xùn),網(wǎng)站設(shè)計(jì)培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)

一級(jí)緩存是SqlSession級(jí)別的緩存。在操作數(shù)據(jù)庫(kù)時(shí)需要構(gòu)造sqlSession對(duì)象,在對(duì)象中有一個(gè)數(shù)據(jù)結(jié)構(gòu)(HashMap)用于存儲(chǔ)緩存數(shù)據(jù)。不同的sqlSession之間的緩存數(shù)據(jù)區(qū)域(HashMap)是互相不影響的。

二級(jí)緩存是mapper級(jí)別的緩存,多個(gè)sqlSession去操作同一個(gè)Mapper的sql語(yǔ)句,多個(gè)sqlSession可以共用二級(jí)緩存,二級(jí)緩存是跨sqlSession的。

為什么要用緩存?

如果緩存中有數(shù)據(jù)就不用從數(shù)據(jù)庫(kù)中獲取,大大提高系統(tǒng)性能。

2.一級(jí)緩存

2.1一級(jí)緩存工作原理

photoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動(dòng)軟件開(kāi)發(fā)培訓(xùn),網(wǎng)站設(shè)計(jì)培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)

 第一次發(fā)起查詢(xún)用戶(hù)id為1的用戶(hù)信息,先去找緩存中是否有id為1的用戶(hù)信息,如果沒(méi)有,從數(shù)據(jù)庫(kù)查詢(xún)用戶(hù)信息。

得到用戶(hù)信息,將用戶(hù)信息存儲(chǔ)到一級(jí)緩存中。

如果sqlSession去執(zhí)行commit操作(執(zhí)行插入、更新、刪除),清空sqlSession中的一級(jí)緩存,這樣做的目的為了讓緩存中存儲(chǔ)的是最新的信息,避免臟讀。

第二次發(fā)去查詢(xún)用戶(hù)id為1的用戶(hù)信息,先去找緩存中是否有id為1的用戶(hù)信息,緩存中有,直接從緩存中獲取用戶(hù)信息。

 2.2一級(jí)緩存測(cè)試

 mybatis默認(rèn)支持一級(jí)緩存,不需要在配置文件去配置。

 按照上邊一級(jí)緩存原理步驟去測(cè)試。

photoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動(dòng)軟件開(kāi)發(fā)培訓(xùn),網(wǎng)站設(shè)計(jì)培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)

 @Test     public void testCache1() throws Exception{         SqlSession sqlSession=sql
        
		

網(wǎng)友評(píng)論