當前位置:首頁 » 硬碟大全 » mybatis緩存制度
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

mybatis緩存制度

發布時間: 2022-04-16 12:09:25

『壹』 mybatis怎麼實現局部緩存

1.1、Mybatis一級緩存測試

1 package me.gacl.test;
2
3 import me.gacl.domain.User;
4 import me.gacl.util.MyBatisUtil;
5 import org.apache.ibatis.session.sqlSession;
6 import org.junit.Test;
7
8 /**
9 * @author gacl
10 * 測試一級緩存
11 */
12 public class TestOneLevelCache {
13
14 /*
15 * 一級緩存: 也就Session級的緩存(默認開啟)
16 */
17 @Test
18 public void testCache1() {
19 SqlSession session = MyBatisUtil.getSqlSession();
20 String statement = "me.gacl.mapping.userMapper.getUser";
21 User user = session.selectOne(statement, 1);
22 System.out.println(user);
23
24 /*
25 * 一級緩存默認就會被使用
26 */
27 user = session.selectOne(statement, 1);
28 System.out.println(user);
29 session.close();
30 /*
31 1. 必須是同一個Session,如果session對象已經close()過了就不可能用了
32 */
33 session = MyBatisUtil.getSqlSession();
34 user = session.selectOne(statement, 1);
35 System.out.println(user);
36
37 /*
38 2. 查詢條件是一樣的
39 */
40 user = session.selectOne(statement, 2);
41 System.out.println(user);
42
43 /*
44 3. 沒有執行過session.clearCache()清理緩存
45 */
46 //session.clearCache();
47 user = session.selectOne(statement, 2);
48 System.out.println(user);
49
50 /*
51 4. 沒有執行過增刪改的操作(這些操作都會清理緩存)
52 */
53 session.update("me.gacl.mapping.userMapper.updateUser",
54 new User(2, "user", 23));
55 user = session.selectOne(statement, 2);
56 System.out.println(user);
57
58 }
59 }

1.2、Mybatis二級緩存測試
1、開啟二級緩存,在userMapper.xml文件中添加如下配置
<mapper namespace="me.gacl.mapping.userMapper">
<!-- 開啟二級緩存 -->
<cache/>

2、測試二級緩存

1 package me.gacl.test;
2
3 import me.gacl.domain.User;
4 import me.gacl.util.MyBatisUtil;
5 import org.apache.ibatis.session.SqlSession;
6 import org.apache.ibatis.session.SqlSessionFactory;
7 import org.junit.Test;
8
9 /**
10 * @author gacl
11 * 測試二級緩存
12 */
13 public class TestTwoLevelCache {
14
15 /*
16 * 測試二級緩存
17 * 使用兩個不同的SqlSession對象去執行相同查詢條件的查詢,第二次查詢時不會再發送SQL語句,而是直接從緩存中取出數據
18 */
19 @Test
20 public void testCache2() {
21 String statement = "me.gacl.mapping.userMapper.getUser";
22 SqlSessionFactory factory = MyBatisUtil.getSqlSessionFactory();
23 //開啟兩個不同的SqlSession
24 SqlSession session1 = factory.openSession();
25 SqlSession session2 = factory.openSession();
26 //使用二級緩存時,User類必須實現一個Serializable介面===> User implements Serializable
27 User user = session1.selectOne(statement, 1);
28 session1.commit();//不懂為啥,這個地方一定要提交事務之後二級緩存才會起作用
29 System.out.println("user="+user);
30
31 //由於使用的是兩個不同的SqlSession對象,所以即使查詢條件相同,一級緩存也不會開啟使用
32 user = session2.selectOne(statement, 1);
33 //session2.commit();
34 System.out.println("user2="+user);
35 }
36 }

1.3、二級緩存補充說明
1. 映射語句文件中的所有select語句將會被緩存。
2. 映射語句文件中的所有insert,update和delete語句會刷新緩存。
3. 緩存會使用Least Recently Used(LRU,最近最少使用的)演算法來收回。
4. 緩存會根據指定的時間間隔來刷新。
5. 緩存會存儲1024個對象
cache標簽常用屬性:
<cache
eviction="FIFO" <!--回收策略為先進先出-->
flushInterval="60000" <!--自動刷新時間60s-->
size="512" <!--最多緩存512個引用對象-->
readOnly="true"/> <!--只讀-->

『貳』 mybatis緩存機制中,默認的回收策略是哪個

Mybatis緩存處理機制 MyBatis緩存介紹 正如大多數持久層框架一樣,MyBatis 同樣提供了一級緩存和二級緩存的支持 一級緩存: 基於PerpetualCache 的 HashMap本地緩存,其存儲作用域為 Session,當 Session flush 或 close 之後

『叄』 mybatis如何設置四級緩存

兩者相同點 Hibernate與MyBatis都可以是通過SessionFactoryBuider由XML配置文件生成SessionFactory,然後由SessionFactory 生成Session,最後由Session來開啟執行事務和SQL語句。其中SessionFactoryBuider,SessionFactory,Session的生命周期都是差不多的。 Hibernate和MyBatis都支持JDBC和JTA事務處理。 Mybatis優勢 MyBatis可以進行更為細致的SQL優化,可以減少查詢欄位。 MyBatis容易掌握,而Hibernate門檻較高。 Hibernate優勢 Hibernate的DAO層開發比MyBatis簡單,Mybatis需要維護SQL和結果映射。 Hibernate對對象的維護和緩存要比MyBatis好,對增刪改查的對象的維護要方便。 Hibernate資料庫移植性很好,MyBatis的資料庫移植性不好,不同的資料庫需要寫不同SQL。 Hibernate有更好的二級緩存機制,可以使用第三方緩存。MyBatis本身提供的緩存機制不佳。

『肆』 mybatis為什麼需要分布式緩存

通常為了減輕資料庫的壓力,我們會引入緩存。在Dao查詢資料庫之前,先去緩存中找是否有要找的數據,如果有則用緩存中的數據即可,就不用查詢數
據庫了。如果沒有才去資料庫中查找。這樣就能分擔一下資料庫的壓力。另外,為了讓緩存中的數據與資料庫同步,我們應該在該數據發生變化的地方加入更新緩存
的邏輯代碼。這樣無形之中增加了工作量,同時也是一種對原有代碼的入侵。這對於有著代碼潔癖的程序員來說,無疑是一種傷害。

MyBatis框架早就考慮到了這些問題,因此MyBatis提供了自定義的二級緩存概念,方便引入我們自己的緩存機制,而不用更改原有的業務邏輯。

『伍』 mybatis具有緩存機制,除了增刪改之外

mybatis的緩存機制
mybatis的緩存分為一級緩存和二級緩存:
1 . mybatis的一級緩存是sqlsession級別的,是基於 HashMap 的本地緩存,不同的 SqlSession 之間的緩存數據區域互不影響。
MyBatis 默認開啟一級緩存。
2 . mybatis的耳機緩存是mapper級別,是基於 HashMap 的本地緩存,多個 SqlSession 可以共用二級緩存,其作用域是 mapper 的同一個 namespace (基本上可以理解一個mapper容器就是一個二級緩存)。
MyBatis 默認關閉二級緩存,如果要使用二級緩存需要在SqlMapConfig.xml文件中通過
<setting name="cacheEnabled" value="true"/>
標簽開啟二級緩的總開關,在需要使用二級緩存的mapper文件中 通過<cache />標簽,開啟這個mapper的二級緩存。

『陸』 mybatis 中的查詢緩存是什麼意思

一、MyBatis的Cache配置 1、全局開關:默認是true,如果它配成false,其餘各個Mapper XML文件配成支持cache也沒用。 <settings> <setting name="cacheEnabled" value="true"/> </settings> 2、各個Mapper XML文件,默認是不採用cache。在配置文件加一行就可以支持cache: <cache /> 3、Mapper XML文件配置支持cache後,文件中所有的Mapper statement就支持了。此時要個別對待某條,需要: <select id="inetAton" parameterType="string" resultType="integer" useCache=「false」> select inet_aton(#{name}) </select> 二、注意的幾個細節 1、如果readOnly為false,此時要結果集對象是可序列化的。 <cache readOnly="false"/> 2、在SqlSession未關閉之前,如果對於同樣條件進行重復查詢,此時採用的是local session cache,而不是上面說的這些cache。 3、MyBatis緩存查詢到的結果集對象,而非結果集數據,是將映射的PO對象集合緩存起來。 說意義不大是在於: a、面對一定規模的數據量,內置的cache方式就派不上用場了; b、對查詢結果集做緩存並不是MyBatis框架擅長的,它專心做的應該是sql mapper。採用此框架的Application去構建緩存更合理,比如採用OSCache、Memcached啥的。

『柒』 MyBatis緩存

可能會有很多人不理解這里,二級緩存帶來的好處遠遠比不上他所隱藏的危害。

  • 緩存是以namespace為單位的,不同namespace下的操作互不影響。

  • insert,update,delete操作會清空所在namespace下的全部緩存。

  • 通常使用MyBatis Generator生成的代碼中,都是各個表獨立的,每個表都有自己的namespace。

『捌』 mybatis的緩存機制是怎麼樣的

你好
關於mybatis的緩存機制:
和其他持久層框架一樣,mybatis也提供了對緩存的支持--一級緩存和二級緩存;
一、緩存介紹
一級緩存:基於PerpetualCache的HashMap的本地緩存,一級緩存的作用域為sqlSession,當sqlSession被flush或close之後,當前sqlSession中的所有緩存都將被清空;
二級緩存:和一級緩存的機制相同,默認也是採用PerpetualCache的HashMap存儲,但二級緩存的作用域是mapper(namespace);
在mybatis的緩存機制中,當緩存(一級緩存的sqlSession/二級緩存的namespace)進行了增刪改的操作之後,當前select的所有數據緩存都將被清除;
總結
二級緩存與一級緩存區別,二級緩存的范圍更大,多個sqlSession可以共享一個UserMapper的二級緩存區域。UserMapper有一個二級緩存區域(按namespace分) ,其它mapper也有自己的二級緩存區域(按namespace分)。每一個namespace的mapper都有一個二緩存區域,兩個mapper的namespace如果相同,這兩個mapper執行sql查詢到數據將存在相同 的二級緩存區域中。
希望對你有幫助

『玖』 mybatis的緩存有幾種

1、一級緩存

MyBatis默認開啟了一級緩存,一級緩存是在SqlSession 層面進行緩存的。即,同一個SqlSession ,多次調用同一個Mapper和同一個方法的同一個參數,只會進行一次資料庫查詢,然後把數據緩存到緩沖中,以後直接先從緩存中取出數據,不會直接去查資料庫。

但是不同的SqlSession對象,因為不用的SqlSession都是相互隔離的,所以相同的Mapper、參數和方法,他還是會再次發送到SQL到資料庫去執行,返回結果。

2、二級緩存

為了克服這個問題,需要開啟二級緩存,是的緩存zaiSqlSessionFactory層面給各個SqlSession 對象共享。默認二級緩存是不開啟的,需要手動進行配置。

<cache/>

如果這樣配置的話,很多其他的配置就會被默認進行,如:

  • 映射文件所有的select 語句會被緩存

  • 映射文件的所有的insert、update和delete語句會刷新緩存

  • 緩存會使用默認的Least Recently Used(LRU,最近最少使用原則)的演算法來回收緩存空間

  • 根據時間表,比如No Flush Interval,(CNFI,沒有刷新間隔),緩存不會以任何時間順序來刷新

  • 緩存會存儲列表集合或對象(無論查詢方法返回什麼)的1024個引用

  • 緩存會被視為是read/write(可讀/可寫)的緩存,意味著對象檢索不是共享的,而且可以很安全的被調用者修改,不幹擾其他調用者或縣城所作的潛在修改

  • 可以在開啟二級緩存時候,手動配置一些屬性

  • <cache eviction="LRU" flushInterval="100000" size="1024" readOnly="true"/>

  • 各個屬性意義如下:

  • eviction:緩存回收策略
    - LRU:最少使用原則,移除最長時間不使用的對象
    - FIFO:先進先出原則,按照對象進入緩存順序進行回收
    - SOFT:軟引用,移除基於垃圾回收器狀態和軟引用規則的對象
    - WEAK:弱引用,更積極的移除移除基於垃圾回收器狀態和弱引用規則的對象

  • flushInterval:刷新時間間隔,單位為毫秒,這里配置的100毫秒。如果不配置,那麼只有在進行資料庫修改操作才會被動刷新緩存區

  • size:引用額數目,代表緩存最多可以存儲的對象個數

  • readOnly:是否只讀,如果為true,則所有相同的sql語句返回的是同一個對象(有助於提高性能,但並發操作同一條數據時,可能不安全),如果設置為false,則相同的sql,後面訪問的是cache的clone副本。

  • 可以在Mapper的具體方法下設置對二級緩存的訪問意願:

  • useCache配置

    如果一條語句每次都需要最新的數據,就意味著每次都需要從資料庫中查詢數據,可以把這個屬性設置為false,如:

  • <select id="selectAll" resultMap="BaseResultMap" useCache="false">

  • 刷新緩存(就是清空緩存)

    二級緩存默認會在insert、update、delete操作後刷新緩存,可以手動配置不更新緩存,如下:

  • <update id="updateById" parameterType="User" flushCache="false" />


  • 3、自定義緩存

    自定義緩存對象,該對象必須實現 org.apache.ibatis.cache.Cache 介面

每次查詢資料庫前,MyBatis都會先在緩存中查找是否有該緩存對象。只有當調用了commit() 方法,MyBatis才會往緩存中寫入數據,數據記錄的鍵為數字編號+Mapper名+方法名+SQL語句+參數格式,值為返回的對象值。