91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-11-30 15:55:51 來源:億速云 閱讀:303 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關mybatis中一級緩存的原理是什么,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

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

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

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

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

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

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

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

@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;
}

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

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

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

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

開啟事務: spring使用ThreadLocal獲取當前資源綁定同一個SQLSession

未開啟事務:每次查詢,spring關閉舊的SslSession,創建一個新的Sqlsession對象,一級緩存補氣作用

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

@Autowired
private LsjmUserMapper lsjmUserMapper;
 
@Override
@Transactional // 開啟事務控制,當前,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;
}

前臺頁面觸發Service后:控制臺打印日志:

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

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

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

有一點需要注意:

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

上述就是小編為大家分享的mybatis中一級緩存的原理是什么了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

修水县| 尚志市| 岳普湖县| 扎赉特旗| 利辛县| 寿光市| 天等县| 炎陵县| 阳曲县| 长顺县| 溧水县| 会泽县| 大石桥市| 新竹市| 汶上县| 布拖县| 龙岩市| 揭阳市| 右玉县| 荣昌县| 裕民县| 乐亭县| 秦皇岛市| 进贤县| 古丈县| 梁平县| 简阳市| 三穗县| 墨竹工卡县| 阿克苏市| 和政县| 镇雄县| 婺源县| 绩溪县| 准格尔旗| 家居| 什邡市| 淮北市| 尼勒克县| 广丰县| 固原市|