1. 程式人生 > >hibernate和mybatis快取的對比

hibernate和mybatis快取的對比

Mybatis快取

分為1級快取和2級快取,2級快取在sessionfactory中,1級快取在session中。

  1. session中的快取在session連線關閉並被連線池回收時清理,或者手動清理

  2. sessionfactory中的快取需要在mybatis配置檔案中手動配置,配置如下:

    1. <settingname="cacheEnabled"value="true"/>
    1. <mappernamespace="dao.userdao">
    2.    ...  select statement ...       <!-- Cache 配置 -->
    3.     <cache
    4.         eviction="FIFO"
    5.         flushInterval="60000"
    6.         size="512"
    7.         readOnly="true"/>
    8. </mapper>

flushInterval:重新整理輪詢時間,每隔這個時間後快取被清理一次。


Hiberante快取

一、why(為什麼要用Hibernate快取?)

hibernate是一個持久層框架,經常訪問物理資料庫

為了降低應用程式對物理資料來源訪問的頻次,從而提高應用程式的執行效能。

快取內的資料是對物理資料來源中的資料的複製,應用程式在執行時從快取讀寫資料,在特定的時刻或事件會同步快取和物理資料來源的資料。

二、what(Hibernate快取原理是怎樣的?)

Hibernate快取包括兩大類:Hibernate一級快取和Hibernate二級快取。

1.Hibernate一級快取又稱為“Session的快取”。

Session內建不能被解除安裝,Session的快取是事務範圍的快取(Session物件的生命週期通常對應一個數據庫事務或者一個應用事務)。

一級快取中,持久化類的每個例項都具有唯一的OID。

2.Hibernate二級快取又稱為“SessionFactory的快取”。

由於SessionFactory物件的生命週期和應用程式的整個過程對應,因此Hibernate二級快取是程序範圍或者叢集範圍的快取,有可能出現併發問題,因此需要採用適當的併發訪問策略,該策略為被快取的資料提供了事務隔離級別。

第二級快取是可選的,是一個可配置的外掛,預設下SessionFactory不會啟用這個外掛。

Hibernate提供了org.hibernate.cache.CacheProvider介面,它充當快取外掛與Hibernate之間的介面卡。

什麼樣的資料適合存放到第二級快取中?   

1) 很少被修改的資料   

2) 不是很重要的資料,允許出現偶爾併發的資料   

3) 不會被併發訪問的資料   

4) 常量資料   

不適合存放到第二級快取的資料?   

1) 經常被修改的資料   

2) 絕對不允許出現併發訪問的資料,如財務資料,絕對不允許出現併發   

3) 與其他應用共享的資料。

3.Session的延遲載入實現要解決兩個問題:正常關閉連線和確保請求中訪問的是同一個session。

Hibernate session就是Java.sql.Connection的一層高階封裝,一個session對應了一個Connection。

http請求結束後正確的關閉session(過濾器實現了session的正常關閉);延遲載入必須保證是同一個session(session繫結在ThreadLocal)。

4.Hibernate查詢物件如何應用快取?

當Hibernate根據ID訪問資料物件的時候,首先從Session一級快取中查;

查不到,如果配置了二級快取,那麼從二級快取中查;

如果都查不到,再查詢資料庫,把結果按照ID放入到快取刪除、更新、增加資料的時候,同時更新快取。

Hibernate與Mybatis對比

首先簡單介紹下兩者的概念

Hibernate :Hibernate 是當前最流行的ORM框架,對資料庫結構提供了較為完整的封裝。

Mybatis:Mybatis同樣也是非常流行的ORM框架,主要著力點在於POJO 與SQL之間的對映關係。

其次具體從幾個方面說一下兩者的區別:

1.兩者最大的區別

針對簡單邏輯,Hibernate和MyBatis都有相應的程式碼生成工具,可以生成簡單基本的DAO層方法。

針對高階查詢,Mybatis需要手動編寫SQL語句,以及ResultMap。而Hibernate有良好的對映機制,開發者無需關心SQL的生成與結果對映,可以更專注於業務流程。

2.開發難度對比

Hibernate的開發難度要大於Mybatis。主要由於Hibernate比較複雜、龐大,學習週期較長。

而Mybatis則相對簡單一些,並且Mybatis主要依賴於sql的書寫,讓開發者感覺更熟悉。

3.sql書寫比較

Mybatis的SQL是手動編寫的,所以可以按需求指定查詢的欄位。不過沒有自己的日誌統計,所以要藉助log4j來記錄日誌。

Hibernate也可以自己寫SQL來指定需要查詢的欄位,但這樣就破壞了Hibernate開發的簡潔性。不過Hibernate具有自己的日誌統計。

4.資料庫擴充套件性比較

Mybatis由於所有SQL都是依賴資料庫書寫的,所以擴充套件性,遷移性比較差。

Hibernate與資料庫具體的關聯都在XML中,所以HQL對具體是用什麼資料庫並不是很關心。

5.快取機制比較

相同點:Hibernate和Mybatis的二級快取除了採用系統預設的快取機制外,都可以通過實現你自己的快取或為其他第三方快取方案,建立介面卡來完全覆蓋快取行為。

不同點:Hibernate的二級快取配置在SessionFactory生成的配置檔案中進行詳細配置,然後再在具體的表-物件對映中配置是那種快取。

MyBatis的二級快取配置都是在每個具體的表-物件對映中進行詳細配置,這樣針對不同的表可以自定義不同的快取機制。並且Mybatis可以在名稱空間中共享相同的快取配置和例項,通過Cache-ref來實現。

兩者比較:因為Hibernate對查詢物件有著良好的管理機制,使用者無需關心SQL。所以在使用二級快取時如果出現髒資料,系統會報出錯誤並提示。

而MyBatis在這一方面,使用二級快取時需要特別小心。如果不能完全確定資料更新操作的波及範圍,避免Cache的盲目使用。否則,髒資料的出現會給系統的正常執行帶來很大的隱患。

6.總結

Hibernate與MyBatis都可以是通過SessionFactoryBuider由XML配置檔案生成SessionFactory,然後由SessionFactory 生成Session,最後由Session來開啟執行事務和SQL語句。

而MyBatis的優勢是MyBatis可以進行更為細緻的SQL優化,可以減少查詢欄位,並且容易掌握。

Hibernate的優勢是DAO層開發比MyBatis簡單,Mybatis需要維護SQL和結果對映。資料庫移植性很好,MyBatis的資料庫移植性不好,不同的資料庫需要寫不同SQL。有更好的二級快取機制,可以使用第三方快取。MyBatis本身提供的快取機制不佳。