hibernate 提供的 load 方法,用於讀取資料,並能充分利用一、二級緩衝,一般,對 load 方法的說明如下:
Session.load/get方法均可以根據指定的實體類和id從資料庫讀取記錄,並返回與之對應的實體物件。其區別在於:如果未能發現合格記錄,get方法返回null,而load方法會拋出一個ObjectNotFoundException。load()方法可返回實體的代理類執行個體,而get方法永遠直接返回實體類。
寫如下的代碼:
public Object LoadObject(Class<?> cClass, Object mKey, boolean bCloseSession)
throws ObjectNotFoundException
{
this.getSession();
Object obj;
try
{
obj = (Object) session.load(cClass, (Serializable) mKey);
}
catch (ObjectNotFoundException e)
{
throw e;
}
if (bCloseSession)
this.closeSession();
return obj;
}
我們的目的很明確,就是如果沒有查到資料,就拋出異常。
但實際的執行情況呢?並非我們所想的,在這裡,他不會拋出異常。而是一直執行,直接從 obj 中讀取資料時,才會拋出ObjectNotFoundException 的異常。因此,異常的捕獲,就要在讀取資料時才行,而不是在擷取對象時。
Test t = (Test) db.LoadObject(Test.class, new String("ff80808121302e360121302e37e30188"));
try
{
System.out.println(t.getCode());
}
catch (ObjectNotFoundException e)
{
e.printStackTrace();
}
對於 load 方法,還有一個問題,那就是,如果在查詢完後馬上關閉 session, 有兩種結果:
第一、如果在 hbm 檔案中,設定 lazy=true, 就會異常:
org.hibernate.LazyInitializationException: could not initialize proxy - no Session
at org.hibernate.proxy.AbstractLazyInitializer.initialize(AbstractLazyInitializer.java:86)
at org.hibernate.proxy.AbstractLazyInitializer.getImplementation(AbstractLazyInitializer.java:140)
at org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.invoke(JavassistLazyInitializer.java:190)
at netway.hibernate.Test_$$_javassist_0.getCode(Test_$$_javassist_0.java)
at BatchTest.testdb(BatchTest.java:107)
at BatchTest.main(BatchTest.java:80)
並從輸出來看,還沒有真正從資料庫執行 select (也就是沒有列印出查詢sql)。
第二、如果設定 lazy=false, 則關閉 session ,不會有上面的問題存在。