欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis中的一級緩存深入剖析

 更新時間:2020年11月27日 16:41:58   作者:C_Liao  
這篇文章主要介紹了mybatis中的一級緩存深入剖析,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

mybatis中提供有一級緩存 和 二級緩存,這里記錄一下一級緩存

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

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

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

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

下面用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后,控制臺打印:

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

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

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

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

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

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

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

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

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

有一點需要注意:

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

以上這篇mybatis中的一級緩存深入剖析就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 詳解SpringMVC的url-pattern配置及原理剖析

    詳解SpringMVC的url-pattern配置及原理剖析

    這篇文章主要介紹了SpringMVC的url-pattern配置及原理剖析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • Java并發(fā)編程之Semaphore的使用簡介

    Java并發(fā)編程之Semaphore的使用簡介

    這篇文章主要介紹了Java并發(fā)編程之Semaphore的使用簡介,幫助大家更好的理解和學習使用Java,感興趣的朋友可以了解下
    2021-04-04
  • Java實戰(zhàn)入門之雙色球彩票小游戲

    Java實戰(zhàn)入門之雙色球彩票小游戲

    這篇文章主要介紹了Java實戰(zhàn)入門之雙色球彩票,文中有非常詳細的代碼示例,對正在學習java的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • 解決idea無法導入識別本地類的問題

    解決idea無法導入識別本地類的問題

    今天做實驗不知道按了哪里不能導入識別本地的類,只有jar包的類,百度搜索也沒有找到合理的解決方案,經(jīng)過朋友援助問題根源找到,下面小編把解決方法分享給大家,需要的朋友參考下吧
    2021-08-08
  • JAVA獲取rabbitmq消息總數(shù)過程詳解

    JAVA獲取rabbitmq消息總數(shù)過程詳解

    這篇文章主要介紹了JAVA獲取rabbitmq消息總數(shù)過程詳解,公司使用的是rabbitMQ,需要做監(jiān)控預警的job去監(jiān)控rabbitMQ里面的堆積消息個數(shù),如何使用rabbitMQ獲取監(jiān)控的隊列里面的隊列消息個數(shù)呢,需要的朋友可以參考下
    2019-07-07
  • 聊聊springboot靜態(tài)資源加載的規(guī)則

    聊聊springboot靜態(tài)資源加載的規(guī)則

    這篇文章主要介紹了springboot靜態(tài)資源加載的規(guī)則,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • 詳解SpringBoot中的tomcat優(yōu)化和修改

    詳解SpringBoot中的tomcat優(yōu)化和修改

    這篇文章主要介紹了詳解SpringBoot中的tomcat優(yōu)化和修改,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • Java使用IO模擬注冊登錄

    Java使用IO模擬注冊登錄

    這篇文章主要為大家詳細介紹了Java使用IO模擬注冊登錄,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • springboot下mybatis-plus開啟打印sql日志的配置指南

    springboot下mybatis-plus開啟打印sql日志的配置指南

    這篇文章主要給大家介紹了關于springboot下mybatis-plus開啟打印sql日志的配置指南的相關資料,還介紹了關閉打印的方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-03-03
  • Mybatis打印替換占位符后的完整Sql教程

    Mybatis打印替換占位符后的完整Sql教程

    這篇文章主要介紹了Mybatis打印替換占位符后的完整Sql教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10

最新評論