程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> JSP編程 >> 關於JSP >> hibernate的緩存和CRUD

hibernate的緩存和CRUD

編輯:關於JSP

     hibernate作為一種現在比較流行的輕量級的ORM框架,2003年開始在國內流行,到目前來說在做持久層上還是占有統治地位的。雖然說豐富靈活的HQL和面對對象的Criteria查詢,把程序員從復雜繁瑣的JDBC中解放了出來,但作為持久層的框架,它的性能才是最重要的核心問題。而性能的核心在於緩存,由於最近在學習這些,所以就把自己的學到的一點東西拿來與大家分享,希望能起到拋磚引玉的效果。
       在說這些之前的先說說hibernate實體對象的三種狀態:
       1.Transient:所謂Transient就是說實體對象在內存中自有存在,與數據庫中的記錄無關。
       2.Persient:Persient對象對應數據庫中的一條記錄,也可以這樣理解,如果一個實體對象與某個session發生關聯,並處於對應session的有效期內,那它就處於Persient狀態。
       3.Detached:所謂的Detached就是處於Persient狀態的對象對應的session關閉之後的狀態。
         我們平時所說的PO(持久化對象)指的就是位於Persient狀態的對象,而VO(值對象)就是指Transient和Detached狀態的對象。
        下面開始說CRUD
       保存:hibernate中保存的方法很多我主要說說下面幾個
            1.save()方法,調用save方法時,首先會在session緩存中查找保存對象如果實體對象已經處於Persient狀態,直接返回,否在實行sql操作,並將保存的實體對象加入session緩存(save方法不會把實體加入二級緩存的),最後對存在的級聯關系進行遞歸處理。
            2.saveOrUpdate()方法:和save方法一樣首先在session緩存中查找,判斷對象是否為為保存狀態,如果對象處於Persient,不執行操作,處於Transient執行save操作,處於Detached調用save將對象與session重新關聯。
          這裡要注意的是批量操作時要適時對session進行flush操作避免OutOfMenoryError。
       刪除:刪除我主要說批量刪除,hibernate在進行批量刪除前,首先必須將所有符合條件的數據加載到內存中(這是所有ORM框架必須面對的問題,這樣主要是為了對目前的內部緩存和二級緩存中數據進行整理,以保存和數據庫的一致性)這樣就面對這如果操作數據量過大,也會出現OutOfMenoryError,所以推薦使用迭代刪除。
       修改:修改主要談談update方法,update和前面的save一樣首先還是要進行在內部緩存中查找,要注意兩點,
           1.Persient狀態的實體對象調用update沒有任何作用,update的SQL將在session.flush()方法中執行。
       查詢:查詢是受緩存影響最大的,主要談一下以下幾種查詢
           1.load和get:這兩者的區別主要是load會在二級緩存中查找,而get在內部緩存中查找不到將跳過二級緩存直接進行sql操作。
           2.createQuery()的list()和iterate()方法,list()實際上無法使用緩存的,他對緩存只寫不讀,而ierate則是首先查找所有符合條件的數據id(首先在本地緩存中查找)在執行相應的select獲得對應記錄,iterate方法的使用最好是查找的實體對象在緩存已經存在,否則查詢性能較低,易產生N+1現象。
           其實還有Query Cache但怕篇幅太長,讓人煩所以就就此停筆,其實緩存是一個很深問題,也很值得研究。
     

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved