自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Hibernate傳播性持久化攻略

開發(fā) 后端
Hibernate默認(rèn)不實現(xiàn)所謂的可到達即Hibernate傳播性持久化(persistence by reachability)的策略。每個Hibernate session的基本操作都有對應(yīng)的級聯(lián)風(fēng)格(cascade style)。

本文向大家介紹Hibernate傳播性持久化(transitive persistence),可能好多人還不了解Hibernate傳播性持久化(transitive persistence),沒有關(guān)系,看完本文你肯定有不少收獲,希望本文能教會你更多東西。

對每一個對象都要執(zhí)行保存,刪除或重關(guān)聯(lián)操作讓人感覺有點麻煩,尤其是在處理許多彼此關(guān)聯(lián)的對象的時候。 一個常見的例子是父子關(guān)系??紤]下面的例子:

如果一個父子關(guān)系中的子對象是值類型(value typed)(例如,地址或字符串的集合)的,他們的生命周期會依賴于父對象,可以享受方便的級聯(lián)操作(Cascading),不需要額外的動作。

父對象被保存時,這些值類型(value typed)子對象也將被保存;父對象被刪除時,子對象也將被刪除。 這對將一個子對象從集合中移除是同樣有效:Hibernate會檢測到,并且因為值類型(value typed)的對象不可能被其他對象引用,所以Hibernate會在數(shù)據(jù)庫中刪除這個子對象。

現(xiàn)在考慮同樣的場景,不過父子對象都是實體(entities)類型,而非值類型(value typed)(例如,類別與個體,或母貓和小貓)。 實體有自己的生命期,允許共享對其的引用(因此從集合中移除一個實體,不意味著它可以被刪除), 并且實體到其他關(guān)聯(lián)實體之間默認(rèn)沒有級聯(lián)操作的設(shè)置。Hibernate默認(rèn)不實現(xiàn)所謂的可到達即Hibernate傳播性持久化(persistence by reachability)的策略。

每個Hibernate session的基本操作 - 包括 persist(), merge(), saveOrUpdate(), delete(), lock(), refresh(), evict(), replicate() - 都有對應(yīng)的級聯(lián)風(fēng)格(cascade style)。 這些級聯(lián)風(fēng)格(cascade style)風(fēng)格分別命名為 create, merge, save-update, delete, lock, refresh, evict, replicate。 如果你希望一個操作被順著關(guān)聯(lián)關(guān)系級聯(lián)傳播,你必須在映射文件中指出這一點。例如:

  1. <one-to-one name="person" cascade="persist"/> 

級聯(lián)風(fēng)格(cascade style)是可組合的:

  1. <one-to-one name="person" cascade="persist,delete,lock"/> 

你可以使用cascade="all"來指定全部操作都順著關(guān)聯(lián)關(guān)系級聯(lián)(cascaded)。 默認(rèn)值是cascade="none",即任何操作都不會被級聯(lián)(cascaded)。

注意有一個特殊的級聯(lián)風(fēng)格(cascade style) delete-orphan,只應(yīng)用于one-to-many關(guān)聯(lián),表明delete()操作 應(yīng)該被應(yīng)用于所有從關(guān)聯(lián)中刪除的對象。

建議:

通常在關(guān)系中應(yīng)用級聯(lián)(cascade)沒什么意義。 級聯(lián)(cascade)通常在 關(guān)系中比較有用。

如果子對象的壽命限定在父親對象的壽命之內(nèi),可通過指定cascade="all,delete-orphan"將其變?yōu)樽詣由芷诠芾淼膶ο?lifecycle object)。

其他情況,你可根本不需要級聯(lián)(cascade)。但是如果你認(rèn)為你會經(jīng)常在某個事務(wù)中同時用到父對象與子對象,并且你希望少打點兒字,可以考慮使用cascade="persist,merge,save-update"。

可以使用cascade="all"將一個關(guān)聯(lián)關(guān)系(無論是對值對象的關(guān)聯(lián),或者對一個集合的關(guān)聯(lián))標(biāo)記為父/子關(guān)系的關(guān)聯(lián)。 這樣對父對象進行save/update/delete操作就會導(dǎo)致子對象也進行save/update/delete操作。

此外,一個持久的父對象對子對象的淺引用(mere reference)會導(dǎo)致子對象被同步save/update。 不過,這個隱喻(metaphor)的說法并不完整。除非關(guān)聯(lián)是關(guān)聯(lián)并且被標(biāo)記為cascade="delete-orphan", 否則父對象失去對某個子對象的引用不會導(dǎo)致該子對象被自動刪除。 父子關(guān)系的級聯(lián)(cascading)操作準(zhǔn)確語義如下:

如果父對象被persist(),那么所有子對象也會被persist()

如果父對象被merge(),那么所有子對象也會被merge()

如果父對象被save(),update()或 saveOrUpdate(),那么所有子對象則會被saveOrUpdate()

如果某個持久的父對象引用了瞬時(transient)或者脫管(detached)的子對象,那么子對象將會被saveOrUpdate()

如果父對象被刪除,那么所有子對象也會被delete()

除非被標(biāo)記為cascade="delete-orphan"(刪除“孤兒”模式,此時不被任何一個父對象引用的子對象會被刪除), 否則子對象失掉父對象對其的引用時,什么事也不會發(fā)生。 如果有特殊需要,應(yīng)用程序可通過顯式調(diào)用delete()刪除子對象。

***,注意操作的級聯(lián)可能是在調(diào)用期(call time)或者寫入期(flush time)作用到對象圖上的。所有的操作,如果允許,都在操作被執(zhí)行的時候級聯(lián)到可觸及的關(guān)聯(lián)實體上。然而,save-upate和delete-orphan是在Session flush的時候才作用到所有可觸及的被關(guān)聯(lián)對象上的。

本文只是大概的說明了Hibernate傳播性持久化的應(yīng)用,可能還有不足的地方,讀者可以查更多的書去了解。

【編輯推薦】

  1. Hibernate中Criteria攻略詳解
  2. 簡述Hibernate三種查詢的應(yīng)用
  3. 談?wù)凥ibernate為何是Java開源項目
  4. 淺析為何學(xué)習(xí)Hibernate
  5. 淺析Hibernate VO與PO區(qū)別
責(zé)任編輯:仲衡 來源: javanb
相關(guān)推薦

2009-09-27 09:55:38

Hibernate持久

2009-09-24 15:42:44

Hibernate對象

2009-09-25 17:19:28

Hibernate持久

2009-09-28 15:50:53

Hibernate創(chuàng)建持久化Product

2009-09-29 16:11:45

Hibernate實現(xiàn)

2009-09-29 16:46:01

創(chuàng)建Hibernate

2009-09-25 09:30:33

Hibernate持久

2009-09-23 15:25:08

Hibernate 3

2009-06-17 16:00:03

Hibernate自定

2009-09-23 17:00:07

Hibernate持久

2009-09-21 17:46:34

Hibernate持久

2009-09-29 10:57:25

設(shè)置Hibernate

2009-09-29 10:37:29

Hibernate持久

2009-09-24 13:03:38

Hibernate C

2009-09-24 14:12:22

Hibernate數(shù)據(jù)

2013-07-09 10:18:58

VDI虛擬化

2009-06-18 15:24:35

Hibernate二級

2023-07-07 08:16:53

Redis持久化

2013-09-12 14:56:02

iOS持久化

2021-05-25 10:20:31

Python持久性編程語言
點贊
收藏

51CTO技術(shù)棧公眾號