Hibernate中有兩個極爲類似的方法get()與load(),他們均可以經過指定的實體類與ID從數據庫中讀取數據,並返回對應的實例,但Hibernate不會搞兩個徹底同樣的方法的,它們間的不一樣在於: html
1.若是找不到符合條件的紀錄,get()方法將返回null.而load()將會報出ObjectNotFoundEcception.
2.load()方法能夠返回實體的代理類實例(這取決於映射文件對類檢索策略的設置,若是<class >中的lazy屬性設置爲false,則採用當即檢索策略,返回實體類,若是lazy屬性設置爲true,則採用延遲檢索策略,返回實體的代理類示例,代理類的實例由hibernate在運行時動態生成,繼承了實體類,所以繼承了實體類的全部屬性和方法。當Hibernate建立實體的代理類實例時,僅僅初始化了它的OID屬性,其餘屬性都爲空),而get()永遠只返回實體類.
3.load()方法能夠充分利用二級緩存和內部緩存的現有數據,而get()方法只在內部緩存中進行查找,如沒有發現對應數據將跳過二級緩存,直接調用SQL完成查找.
hibernate中get方法和load方法的根本區別在於:若是你使用load方法,hibernate認爲該id對應的對象(數據庫記錄)在數據庫 中是必定存在的,因此它能夠放心的使用,它能夠放心的使用代理來延遲加載該對象。在用到對象中的其餘屬性數據時才查詢數據庫,可是萬一數據庫中不存在該記 錄,那沒辦法,只能拋異常,所說的load方法拋異常是指在使用該對象的數據時,數據庫中不存在該數據時拋異常,而不是在建立這個對象時。因爲 session中的緩存對於hibernate來講是個至關廉價的資源,因此在load時會先查一下session緩存看看該id對應的對象是否存在,不存在則建立代理。因此若是你知道該id在數據庫中必定有對應記錄存在就可使用load方法來實現延遲加載。
對於get方法,hibernate會確認一下該id對應的數據是否存在,首先在session緩存中查找,而後在二級緩存中查找,尚未就查數據庫,數據庫中沒有就返回null。
對於第2點,雖然好多書中都這麼說:「get()永遠只返回實體類」,但實際上這是不正確的,get方法若是在session緩存中找到了該id 對應的對象,若是恰好該對象前面是被代理過的,如被load方法使用過,或者被其餘關聯對象延遲加載過,那麼返回的仍是原先的代理對象,而不是實體類對 象,若是該代理對象尚未加載實體數據(就是id之外的其餘屬性數據),那麼它會查詢二級緩存或者數據庫來加載數據,可是返回的仍是代理對象,只不過已經 加載了實體數據。
前面已經講了,get方法首先查詢session緩存,沒有的話查詢二級緩存,最後查詢數據庫;反而load方法建立時首先查詢session緩存,沒有就建立代理,實際使用數據時才查詢二級緩存和數據庫。
總之對於get和load的根本區別,一句話,hibernate對於load方法認爲該數據在數據庫中必定存在,能夠放心的使用代理來延遲加載,若是在使用過程當中發現了問題,只能拋異常;而對於get方法,hibernate必定要獲取到真實的數據,不然返回null。
===================================================================
query.list()與query.iterate()區別:
Iterator iterate():
Return the query results as an Iterator. If the query contains multiple results pre row, the results are returned in an instance of Object[].
Entities returned as results are initialized on demand. The first SQL query returns identifiers only.
List list():
Return the query results as a List. If the query contains multiple results pre row, the results are returned in an instance of Object[].
list: 結果存入緩存,但不從緩存裏面取;查詢時屬性連同id一塊兒找出來,只有「一句」select;
iterate:結果存入緩存,並在緩存中查找結果;查詢時先找出全部的 id,而後根據 id 到緩存裏面查找,若是沒有命中,再到數據庫中查找該id對應的其餘屬性。可能會有多行 select。 sql
參考網址: 數據庫
1. http://blog.sina.com.cn/s/blog_921a5fc7010109rf.html 緩存
2. http://zhidao.baidu.com/link?url=1D4wl_aM20oOzjq-3vEZGl03Ldme76SHOvQck2p_6SR-c_0346woKIGC888tGcbb... session
其餘: ide
get()方法執行的時候,會當即向數據庫發出查詢語句, 而load()方法返回的是一個代理(此代理中只有一個id屬性),只有等真正使用該對象屬性的時候,纔會發出sql語句 url 2.若是數據庫中沒有對應的記錄,get()方法返回的是null.而load()方法出現異常ObjectNotFoundException spa |