關於hibernate中物件的三種狀態分析
一,首先hibernate中物件的狀態有三種:瞬態、遊離態和持久態,三種狀態轉化的方法都是通過session來呼叫,瞬態到持久態的方法有save()、saveOrUpdate()、get()、load();持久態到瞬態的方法有delete();遊離態到持久態的方法有update()、saveOrUpdate()、lock();持久態到遊離態的方法有:session.close()、session.evict()、session.clear()。
二,Hibernate的狀態
hibernate的各種儲存方式的區(save,persist,update,saveOrUpdte,merge,flush,lock)及 物件的三種狀態
hibernate的儲存
hibernate對於物件的儲存提供了太多的方法,他們之間有很多不同,這裡細說一下,以便區別。
一、預備知識
在所有之前,說明一下,對於hibernate,它的物件有三種狀態,transient、persistent、detached
下邊是常見的翻譯辦法:
transient:瞬時態或者臨時態
(new DeptPo(1,”行政部”,20,”行政相關”),該po的例項和session沒有關聯,該po的例項處於transient)
persistent:持久化狀態
(和資料庫中記錄想影射的Po例項,它的狀態是persistent, 通過get和load等得到的物件都是persistent)
detached:脫管狀態或者遊離態
(1)當通過get或load方法得到的po物件它們都處於persistent,但如果執行delete(po)時(但不能執行事務),該 po狀態就處於detached, (表示和session脫離關聯),因delete而變成遊離態可以通過save或saveOrUpdate()變成持久態
(2)當把session關閉時,session快取中的persistent的po物件也變成detached
因關閉session而變成遊離態的可以通過lock、save、update變成持久態
持久態例項可以通過呼叫 delete()變成脫管狀態。
通過get()或load()方法得到的例項都是持久化狀態的。
脫管狀態的例項可以通過呼叫lock()或者replicate()進行持久化。
save()和persist()將會引發SQL的INSERT,delete()會引發SQLDELETE,
而update()或merge()會引發SQL UPDATE。對持久化(persistent)例項的修改在重新整理提交的時候會被檢測到,它也會引起SQL UPDATE。
saveOrUpdate()或者replicate()會引發SQLINSERT或者UPDATE
二、save 和update區別
把這一對放在第一位的原因是因為這一對是最常用的。
save的作用是把一個新的物件儲存
update是把一個脫管狀態的物件或自由態物件(一定要和一個記錄對應)更新到資料庫
三、update 和saveOrUpdate區別
這個是比較好理解的,顧名思義,saveOrUpdate基本上就是合成了save和update,而update只是update;引用hibernate reference中的一段話來解釋他們的使用場合和區別
通常下面的場景會使用update()或saveOrUpdate():
程式在第一個session中載入物件,接著把session關閉
該物件被傳遞到表現層
物件發生了一些改動
該物件被返回到業務邏輯層最終到持久層
程式建立第二session呼叫第二個session的update()方法持久這些改動
saveOrUpdate(po)做下面的事:
如果該po物件已經在本session中持久化了,在本session中執行saveOrUpdate不做任何事
如果savaOrUpdate(新po)與另一個與本session關聯的po物件擁有相同的持久化標識(identifier),丟擲一個異常
org.hibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session: [org.itfuture.www.po.Xtyhb#5]
saveOrUpdate如果物件沒有持久化標識(identifier)屬性,對其呼叫save() ,否則update() 這個物件
四、persist和save區別
這個是最迷離的一對,表面上看起來使用哪個都行,在hibernate reference文件中也沒有明確的區分他們.
這裡給出一個明確的區分。(可以跟進src看一下,雖然實現步驟類似,但是還是有細微的差別)
主要內容區別:
1,persist把一個瞬態的例項持久化,但是並"不保證"識別符號(identifier主鍵對應的屬性)被立刻填入到持久化例項中,識別符號的填入可能被推遲到flush的時候。
2,save, 把一個瞬態的例項持久化識別符號,及時的產生,它要返回識別符號,所以它會立即執行Sql insert
五、saveOrUpdate,merge和update區別
比較update和merge
update的作用上邊說了,這裡說一下merge的
如果session中存在相同持久化標識(identifier)的例項,用使用者給出的物件覆蓋session已有的持久例項
(1)當我們使用update的時候,執行完成後,會丟擲異常
(2)但當我們使用merge的時候,把處理自由態的po物件A的屬性copy到session當中處於持久態的po的屬性中,執行完成後原來是持久狀態還是持久態,而我們提供的A還是自由態
六、flush和update區別
這兩個的區別好理解
update操作的是在自由態或脫管狀態(因session的關閉而處於脫管狀態)的物件//updateSQL
而flush是操作的在持久狀態的物件。
預設情況下,一個持久狀態的物件的改動(包含set容器)是不需要update的,只要你更改了物件的值,等待hibernate flush就自動更新或儲存到資料庫了。hibernate flush發生在以下幾種情況中:
1, 呼叫某些查詢的和手動flush(),session的關閉、SessionFactory關閉結合
get()一個物件,把物件的屬性進行改變,把資源關閉。
2,transaction commit的時候(包含了flush)
七、lock和update區別
update是把一個已經更改過的脫管狀態的物件變成持久狀態
lock是把一個沒有更改過的脫管狀態的物件變成持久狀態(針對的是因Session的關閉而處於脫管狀態的po物件(2),不能針對因delete而處於脫管狀態的po物件)
對應更改一個記錄的內容,兩個的操作不同:
update的操作步驟是:
(1)屬性改動後的脫管的物件的修改->呼叫update
lock的操作步驟是:
(2)呼叫lock把未修改的物件從脫管狀態變成持久狀態-->更改持久狀態的物件的內容-->等待flush或者手動flush
八、clear和evcit的區別
clear完整的清除session快取
evcit(obj)把某個持久化物件從session的快取中清空。
session.lock(xtyhb,LockMode.NONE);//表示直接到快取中去找變成持久態的物件
session.lock(xtyhb,LockMode.READ);//先通過ID讀資料庫該記錄的ID看是否有該記錄,如果有接著到快取中去找變成持久態的物件
在Hibernate中,物件有三種狀態:臨時狀態、持久狀態和遊離狀態。
也叫:瞬時態(Transient)、持久態(Persistent)、脫管態(Detached)。處於持久態的物件也稱為PO(Persistence Object),瞬時物件和脫管物件也稱為VO(Value Object)。
臨 時狀態:當new一個實體物件後,這個物件處於臨時狀態,即這個物件只是一個儲存臨時資料的記憶體區域,如果沒有變數引用這個物件,則會被jre垃圾回收機 制回收。這個物件所儲存的資料與資料庫沒有任何關係,除非通過Session的save或者SaveOrUpdate把臨時物件與資料庫關聯,並把資料插 入或者更新到資料庫,這個物件才轉換為持久物件。
例如:Emp e=new Emp(); //建立臨時物件
e.setEmpno((long) 8888);
e.setEName("mike");
...
EmpDAO d=new EmpDAO();
d.save(e); //持久化
...
持久狀態:持久化物件的例項在資料庫中有對應的記錄,並擁有一個持久化表示(ID)。對持久化物件進行delete操作後,資料庫中對應的記錄將被刪除,那麼持久化物件與資料庫記錄不再存在對應關係,持久化物件變成臨時狀態。
持久化物件被修改變更後,不會馬上同步到資料庫,知道資料庫事務提交。在同步之前,持久化物件是髒的(Dirty)。
例如:
Emp e=new Emp(); //建立了臨時的物件
EmpDAO edao= new empDAO();
e=edao.findbyEmpno((long) 7786); //使物件與資料庫記錄對應,從而持久化
e.setEname("新的名字"); //修改了持久化物件,使之處於 Dirty
......
edao.saveorupdate(e); //儲存,但是仍然 Dirty
tran.commit(); //提交,實現與資料庫同步,不再Dirty
......
遊離狀態:當Session進行了Close、Clear或者evict後,持久化物件雖然擁有持久化識別符號和與資料庫對應記錄一致的值,但是因為 會話已經消失,物件不在持久化管理之內,所以處於遊離狀態(也叫:脫管狀態)。遊離狀態的物件與臨時狀態物件是十分相似的,只是它還含有持久化標識。
瞬時態
由new命令開闢記憶體空間的java物件,
eg. Person person = new Person("xxx", "xx");
如果沒有變數對該物件進行引用,它將被java虛擬機器回收。
瞬時物件在記憶體孤立存在,它是攜帶資訊的載體,不和資料庫的資料有任何關聯關係,在Hibernate中,可通過session的save()或 saveOrUpdate()方法將瞬時物件與資料庫相關聯,並將資料對應的插入資料庫中,此時該瞬時物件轉變成持久化物件。
持久態
處於該狀態的物件在資料庫中具有對應的記錄,並擁有一個持久化標識。如果是用hibernate的delete()方法,對應的持久物件就變成瞬時物件,因資料庫中的對應資料已被刪除,該物件不再與資料庫的記錄關聯。
當一個session執行close()或clear()、evict()之後,持久物件變成脫管物件,此時持久物件會變成脫管物件,此時該物件雖然具有資料庫識別值,但它已不在HIbernate持久層的管理之下。
持久物件具有如下特點:
1. 和session例項關聯;
2. 在資料庫中有與之關聯的記錄。
脫管態
當與某持久物件關聯的session被關閉後,該持久物件轉變為脫管物件。當脫管物件被重新關聯到session上時,並再次轉變成持久物件。
脫管物件擁有資料庫的識別值,可通過update()、saveOrUpdate()等方法,轉變成持久物件。
脫管物件具有如下特點:
1. 本質上與瞬時物件相同,在沒有任何變數引用它時,JVM會在適當的時候將它回收;
2. 比瞬時物件多了一個數據庫記錄標識值。
相關推薦
深入淺出Hibernate中的三種狀態
學過hibernate的人都可能都知道hibernate有三種狀態,transient(瞬時狀態),persistent(持久化狀態)以及detached(離線狀態),大傢伙也許也知道這三者之間的區別,比如瞬時狀態就是剛new出來一個物件,還沒有被儲存
關於hibernate中物件的三種狀態分析
一,首先hibernate中物件的狀態有三種:瞬態、遊離態和持久態,三種狀態轉化的方法都是通過session來呼叫,瞬態到持久態的方法有save()、saveOrUpdate()、get()、load
Hibernate物件三種狀態詳細分析(轉自http://blog.csdn.net/redarmy_chen/article/details/7069482)
在hibernate中有三種狀態:瞬時態(Transient)、 持久態(Persistent)、脫管態(Detached)。處於持久態的物件也稱為PO(Persistence Object),瞬時物件和脫管物件也稱為VO(Value Object)。通過自己在網上的搜尋,
Hibernate-----物件三種狀態
瞬時態(臨時態):transient,session沒有快取物件,資料庫也沒有對應記錄。 &nb
java物件中的三種狀態和髒檢查及重新整理快取機制
瞬時狀態 瞬時狀態又稱臨時狀態.如果java物件與資料庫中的資料沒有任何的關聯,即此java物件在資料庫中沒有相關聯的記錄,此時java物件的狀態為瞬時狀態,session對於 瞬時狀態的ava物件是一無所知的,當物件不再被其他物件引用時,它的所有資料也就丟失了,物件將會被java虛擬機器按照垃圾回收
Java三大框架之——Hibernate中的三種資料持久狀態和快取機制
Hibernate中的三種狀態 瞬時狀態:剛建立的物件還沒有被Session持久化、快取中不存在這個物件的資料並且資料庫中沒有這個物件對應的資料為瞬時狀態這個時候是沒有OID。 持久狀態:物件經過Session持久化操作,快取中存在這個物件的資料為持久狀
hibernate資料的三種狀態
Hibernate 資料持久化的三種狀態: 一、 瞬時物件(Transient Object): 使用new操作符初始化的物件不是立刻就持久的。它們的狀態是瞬時的,也就是說它們沒有任何跟資料庫表相關聯的行為,只要應用不再引用這些物件(不再被任何其它物件所引用),它們
持久化物件三種狀態之間的轉換
1.Hibernate持久化物件的三種狀態總結: 1.瞬態:使用new剛建立的並且還未與Hibernate Session關聯的物件此時處於瞬態。瞬態物件還不會與資料庫之間進行關聯 2.持久化:持久化例項在資料庫中有對應的記錄,持久化例項可以
Hibernate中物件的三種狀態及相互轉化
1. 瞬時狀態 (Transient) 當我們通過Java的new關鍵字來生成一個實體物件時,這時這個實體物件就處於自由狀態,如下: Customer customer=new Customer(“zx”,27,images); 這時cus
Hibernate中持久化物件的三種狀態簡述
持久化物件的三種狀態簡述 在Hibernate中持久化類的物件可以劃分為三種狀態,分別是: 瞬態,持久態,脫管態。 一、瞬時狀態(Transient) 瞬時物件特點: (1) 不和 Session 例項關聯 (2) 在資料庫中沒有和瞬時物件關聯的記錄 通過
Hibernate中物件的三種狀態,以及三種狀態間的轉化方法
在Hibernate中有三種狀態,對它的深入理解,才能更好的理解hibernate的執行機理,剛開始不太注意這些概念,後來被別人問到了,說是面試題,才發現它是重要的。對於需要持久化的JAVA物件,在它的生命週期中有三種狀態,而且互相轉化。 Hibernate三種狀態之一
hibernate中物件的三種狀態:瞬時態、脫管態、持久態
物件的三種狀態: 瞬時態:也叫臨時態,與session沒有關聯,沒有id,在資料庫中沒有記錄 脫管態:也叫遊離態,與session沒有關聯,但在資料庫中有對應的id,有這條記錄 持
Hibernate中物件的三種狀態
Hibernate中的物件有三種狀態: 瞬時狀態 (Transient),持久狀態 (Persistent),遊離狀態 (Detached)(也叫託管狀態) 1. 瞬時狀態 (Transient) 當我們通過Java的new關鍵字來生成一個實體物件時,這時這
Hibernate框架中物件的三種狀態
一、三種狀態簡介1、瞬時態:transient,session沒有快取物件,資料庫也沒有對應記錄。直白說就說:沒有與Hibernate產生關聯也沒有與資料庫裡的記錄產生關聯(有關聯就是與資料庫中的ID有對應)2、持久態:persistent,session快取物件,資料庫有記
Hibernate中物件的編寫要求及物件的三種狀態
介紹Hibernate是一個ORM(Object-Relational-Mapping,物件關係對映)框架,它提供了另一種管理資料庫的思想,即將表與物件進行對應,資料庫中的每一張表都與一個物件對應,在Hibernate中對於資料的操作都要在session中進行,session
Hibernate中Java物件的三種狀態以及之間的轉換 ----Hibernate_4
Hibernate框架通過 Session來管理 Java物件的狀態 瞬時狀態持久狀態遊離狀態瞬時狀態(Transient) 通過new 建立物件之後,並沒有立刻持久化,就是沒有儲存到資料庫,還儲存在記憶體中, 這就是瞬時狀態,Session對瞬時狀態是一無所知的,不受Se
Hibernate中對象的三種狀態
less val ssi action 之前 一個數據庫 cti 事務提交 color 一 . 在hibernate中,對象有三種狀態:臨 時狀態(Transient)、持久狀態(Persistent)和遊離狀態(Detached)。 處於持久態的對象也稱為 PO
物件的三種狀態(hibernate管理的物件)
臨時狀態 當物件被new出來的時候就是臨時狀態 持久狀態 hibernate通過管理物件來操作資料庫,這裡物件指的是持久態的物件 程式碼: // 測試 //呼叫自己寫的方法獲取到session Session session
分享知識-快樂自己:Hibernate物件的三種狀態
圖解: 1):瞬時狀態(Transient) 物件與session沒有關聯,資料庫中沒有對應的資料。 一般new出來的物件便是瞬時物件。 對瞬時物件使用save()方法便使之成為持久物件。 由於資料庫中沒有對應的資料,所以對瞬時物件使用update()方法無效。
hibernate中實體類的三種狀態和crud操作
實體類 private int uid; private String name; private String age; private String address; public int getUid() { return uid;