Hibernate update 和 merge 、saveOrUpdate的區別

this.getSession().update(obj);

this.getSession().merge(obj);

this.getSession().saveOrUpdate(obj);

1. update 和 merge的區別數據庫

首先在執行更新操做的時候,二者都必需要有id緩存

update是直接執行update 語句,執行後狀態爲持久化狀態session

而merge則不同:ide

1. 若是session中有與之對應的對象,也就是主鍵相同,則會把要保存的obj的值copy給session中的對象,而後update被複制後的session中的對象this

2. 若是session中沒有,則會先從數據庫中select,而後把obj給查出來的對象copy,則update查出來的對象。spa

3. 因此merge會先select 再updatehibernate

4. 因此merge後原來的對象obj狀態爲脫管。code

 

================如下爲摘抄=============對象

2、save 和update區別
把這一對放在第一位的緣由是由於這一對是最經常使用的。
save的做用是把一個新的對象保存
update是把一個脫管狀態的對象或自由態對象(必定要和一個記錄對應)更新到數據庫blog

3、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() 這個對象

4、persist和save區別
這個是最迷離的一對,表面上看起來使用哪一個都行,在hibernate reference文檔中也沒有明確的區分他們.
這裏給出一個明確的區分。(能夠跟進src看一下,雖然實現步驟相似,可是仍是有細微的差異)
主要內容區別:
1,persist把一個瞬態的實例持久化,可是並"不保證"標識符(identifier主鍵對應的屬性)被馬上填入到持久化實例中,標識符的填入可能被推遲到flush的時候。

2,save, 把一個瞬態的實例持久化標識符,及時的產生,它要返回標識符,因此它會當即執行Sql insert

5、saveOrUpdate,merge和update區別
比較update和merge
update的做用上邊說了,這裏說一下merge的
若是session中存在相同持久化標識(identifier)的實例,用用戶給出的對象覆蓋session已有的持久實例 
(1)當咱們使用update的時候,執行完成後,會拋出異常 
(2)但當咱們使用merge的時候,把處理自由態的po對象A的屬性copy到session當中處於持久態的po的屬性中,執行完成後原來是持久狀態仍是持久態,而咱們提供的A仍是自由態

6、flush和update區別
這兩個的區別好理解
update操做的是在自由態或脫管狀態(因session的關閉而處於脫管狀態)的對象//updateSQL
而flush是操做的在持久狀態的對象。
默認狀況下,一個持久狀態的對象的改動(包含set容器)是不須要update的,只要你更改了對象的值,等待hibernate flush就自動更新或保存到數據庫了。hibernate flush發生在如下幾種狀況中:
1, 調用某些查詢的和手動flush(),session的關閉、SessionFactory關閉結合 
get()一個對象,把對象的屬性進行改變,把資源關閉。
2,transaction commit的時候(包含了flush)

7、lock和update區別update是把一個已經更改過的脫管狀態的對象變成持久狀態lock是把一個沒有更改過的脫管狀態的對象變成持久狀態(針對的是因Session的關閉而處於脫管狀態的po對象(2),不能針對因delete而處於脫管狀態的po對象)對應更改一個記錄的內容,兩個的操做不一樣:update的操做步驟是:(1)屬性改動後的脫管的對象的修改->調用updatelock的操做步驟是:(2)調用lock把未修改的對象從脫管狀態變成持久狀態-->更改持久狀態的對象的內容-->等待flush或者手動flush8、clear和evcit的區別clear完整的清除session緩存evcit(obj)把某個持久化對象從session的緩存中清空。

相關文章
相關標籤/搜索