hibernate的查詢的比較
hibernate的查詢有很多,Query,find,Criteria,get,load
query使用hsql語句,可以設置參數是常用的一種方式
criteria的方式,盡量避免了寫hql語句,看起來更面向對象了。
find方式,這種方式已經被新的hibernate丟棄見這里
http://www.tkk7.com/dreamstone/archive/2007/07/28/133053.html
get和load方式是根據id取得一個記錄
下邊詳細說一下get和load的不同,因為有些時候為了對比也會把find加進來。
1,從返回結果上對比:
load方式檢索不到的話會拋出org.hibernate.ObjectNotFoundException異常
get方法檢索不到的話會返回null
2,從檢索執(zhí)行機制上對比:
get方法和find方法都是直接從數據庫中檢索
而load方法的執(zhí)行則比較復雜
1,首先查找session的persistent Context中是否有緩存,如果有則直接返回
2,如果沒有則判斷是否是lazy,如果不是直接訪問數據庫檢索,查到記錄返回,查不到拋出異常
3,如果是lazy則需要建立代理對象,對象的initialized屬性為false,target屬性為null
4, 在訪問獲得的代理對象的屬性時,檢索數據庫,如果找到記錄則把該記錄的對象復制到代理對象的target
上,并將initialized=true,如果找不到就拋出異常 。