欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

mybatis中一級緩存的原理是什么-創(chuàng)新互聯(lián)

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)mybatis中一級緩存的原理是什么,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

開平網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)公司!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站設(shè)計等網(wǎng)站項目制作,到程序開發(fā),運營維護。成都創(chuàng)新互聯(lián)公司于2013年創(chuàng)立到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選成都創(chuàng)新互聯(lián)公司

一級緩存(mybatis中默認開啟)


SqlSession級別的緩存,操作數(shù)據(jù)庫時需要構(gòu)造SQLSession對象, 在對象中有一個數(shù)據(jù)結(jié)構(gòu)(HashMap)用于存儲緩存數(shù)據(jù),不同的SQLSession對象之間的緩存數(shù)據(jù)是不共享的,即獨立的

根據(jù)第一點,簡單一點講就是一級緩存是屬于對象的(個人記法)

從別處搞來一個圖,便于我們理解:

mybatis中一級緩存的原理是什么

下面用spring整合mybatis來測試一下mybatis的一級緩存:

1、下面是service層實現(xiàn), 可以看到,我兩次查詢了同一個數(shù)據(jù),理論上由于mybatis中默認開啟一級緩存, 那么第二次肯定時要從緩存中獲取,而不是創(chuàng)建SqlSession對象重新從數(shù)據(jù)庫獲取

@Autowired
private LsjmUserMapper lsjmUserMapper;
 
@Override
public LsjmUser getUser() {
 // 第一次查詢
 LsjmUser user = lsjmUserMapper.getUserByName("300");
 System.out.println(user.toString());
 
 // 第二次查詢
 LsjmUser user1 = lsjmUserMapper.getUserByName("300");
 System.out.println(user1.toString());
 return user;
}

前臺頁面觸發(fā)這個service后,控制臺打印:

從日志信息可以很明顯的看到,代碼中的兩次查詢構(gòu)建了兩個SqlSession對象,也就是說第二次查詢并沒有從前一次的SqlSession緩存中獲取,而是自己新建一個SQLSession對象,重新查詢,,看似,mybatis的一級緩存失效了?

mybatis中一級緩存的原理是什么

2、spring 中 結(jié)合 mybatis中,默認情況下,數(shù)據(jù)庫處于自動提交模式,每一條sql語句處于一個單獨的事務(wù)中,語句執(zhí)行完畢時,如果執(zhí)行成功則隱式提交事務(wù)。而mybatis的一級緩存在這種情況下是無效的,想要一級緩存起作用,則要開啟事務(wù):

開啟事務(wù): spring使用ThreadLocal獲取當(dāng)前資源綁定同一個SQLSession

未開啟事務(wù):每次查詢,spring關(guān)閉舊的SslSession,創(chuàng)建一個新的Sqlsession對象,一級緩存補氣作用

下面Service層中的代碼同樣對同一個數(shù)據(jù)查詢了兩次,這次開啟了事務(wù)管理

@Autowired
private LsjmUserMapper lsjmUserMapper;
 
@Override
@Transactional // 開啟事務(wù)控制,當(dāng)前,spring配置文件中得先配置好
public LsjmUser getUser() {
 // 第一次查詢
 LsjmUser user = lsjmUserMapper.getUserByName("300");
 System.out.println(user.toString());
 
 // 第二次查詢
 LsjmUser user1 = lsjmUserMapper.getUserByName("300");
 System.out.println(user1.toString());
 return user;
}

前臺頁面觸發(fā)Service后:控制臺打印日志:

可以看出來第一次查詢時,構(gòu)造了一個SqlSession對象,從數(shù)據(jù)庫查詢數(shù)據(jù),然后將查詢的結(jié)果存儲到一級緩存SqlSession中,第二次查詢時,直接Fetched SqlSession,而不是再重新建一個,此時就是從緩存中直接取數(shù)據(jù)了

mybatis中一級緩存的原理是什么

開啟事務(wù)后取如何取到同一個SqlSession,源碼解析可以參考這里:spring結(jié)合mybatis時一級緩存失效問題

有一點需要注意:

如果對某個SqlSession執(zhí)行了commit,則會清空這個SqlSession中的一級緩存,目的是為了防止臟讀,在上面的例子中,如果第一次查詢后,做了一次更新操作,然后sqlSession.commit()了,此時會清空整個SqlSession的一級緩存,那么第二次查詢時就得重新的從數(shù)據(jù)中查詢了。

上述就是小編為大家分享的mybatis中一級緩存的原理是什么了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)頁名稱:mybatis中一級緩存的原理是什么-創(chuàng)新互聯(lián)
文章來源:http://chinadenli.net/article30/decjpo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動網(wǎng)站建設(shè)關(guān)鍵詞優(yōu)化面包屑導(dǎo)航網(wǎng)站內(nèi)鏈網(wǎng)站導(dǎo)航用戶體驗

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作