偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Hibernate的Orders OrderItem類

開發(fā) 后端
這里介紹Hibernate的Orders OrderItem類,我們需要同時(shí)檢查Order OrderItem。就如前面所提到的,我們添加一項(xiàng)Product到一個(gè)Order中,它將變成一個(gè)Order OrderItem在內(nèi)部保存一個(gè)OrderItem集。

Hibernate還是比較常用的,于是我研究了一下Orders OrderItem,在這里拿出來和大家分享一下,希望對大家有用。

Orders OrderItem

有時(shí)一個(gè)一個(gè)地操縱對象確實(shí)可行,但是我們希望能夠級聯(lián)加載和更新?,F(xiàn)在我們來看如何做到這一點(diǎn)。

我們需要同時(shí)檢查Order OrderItem。就如前面所提到的,我們添加一項(xiàng)Product到一個(gè)Order中,它將變成一個(gè)Order OrderItem在內(nèi)部保存一個(gè)OrderItem集。我們希望保存Order,讓Hibernate來做其他工作:保存OrderItem和更新所添加的Product的可用庫存(數(shù)量)。聽起來很復(fù)雜,但實(shí)際上非常簡單。Hibernate知道如何處理一對一、一對多、多對一和多對多方式中的相關(guān)對象。我們將從映射文件開始。

Order.hbm.xml

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" 
    "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"
    > 
  3. <hibernate-mapping> 
  4. <class name="test.hibernate.Order" table="orders"> 
  5. <id name="id" type="string" unsaved-value="null" > 
  6. <column name="id" sql-type="char(32)" not-null="true"/> 
  7. <generator class="uuid.hex"/> 
  8. </id> 
  9. <property name="date"> 
  10. <column name="order_date"sql-type="datetime" not-null="true"/> 
  11. </property> 
  12. <property name="priceTotal"> 
  13. <column name="price_total"sql-type="double" not-null="true"/> 
  14. </property> 
  15.    
  16. <set name="orderItems" table="order_items" inverse="true"cascade="all"> 
  17. <key column="order_id" /> 
  18. <one-to-many class="test.hibernate.OrderItem" /> 
  19. </set> 
  20.    
  21. </class> 
  22. </hibernate-mapping> 

這個(gè)映射文件非常易于理解,除了最后一個(gè)元素<set>。它表示了不同類之間的連接,在我們的例子中,這些類是Order和 OrderItem。屬性和子元素很容易理解:一個(gè)Set類型的字段,名為orderItems(參見上面的Order源代碼),它包含類型為test.hibernate.OrderItem的對象,正如<one-to-many>子元素所解釋的那樣。這些對象被持久化在表order_items中,order_id列包含OrderItem類型的對象的鍵。

 cascade="all"是一個(gè)非常重要的屬性。它解釋了在操縱連接到的對象時(shí),Hibernate如何動作。在我們的例子中,當(dāng)創(chuàng)建一個(gè)Order時(shí),我們無疑希望它所有的OrderItem也被創(chuàng)建;當(dāng)然,當(dāng)一個(gè)Order被刪除時(shí),我們也希望它所有的OrderItem也被刪除。Cascade屬性還有另外三個(gè)選項(xiàng)(none、save-update和delete),我們將在下面的示例中看一下如何使用它們。

這個(gè)對象比較有意思。它的實(shí)例自動在Order中創(chuàng)建,基本上不會存在于其外。然而,由于它們在創(chuàng)建Order時(shí)代表Product,所以我們需要它們。如果一項(xiàng)產(chǎn)品的價(jià)格改變了,我們無疑不希望所有相關(guān)的OrderItem以及Order的價(jià)格被改變。我們需要的只是在OrderItem創(chuàng)建時(shí)更新Product的可用庫存。最后,當(dāng)一項(xiàng)Order被刪除時(shí),其OrderItem也被刪除,但我們不能改變Product!聽上去很復(fù)雜,特別是要編寫所有這些SQL語句的話。但Hibernate把它們壓縮成了映射文件中的兩行!

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" 
    "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"
    > 
  3.  
  4. <hibernate-mapping> 
  5. <class name="test.hibernate.OrderItem"table="order_items"> 
  6. <id name="id" type="string" unsaved-value="null" > 
  7. <column name="id" sql-type="char(32)"not-null="true"/> 
  8. <generator class="uuid.hex"/> 
  9. </id> 
  10. <property name="orderId" insert="false"update="false"> 
  11. <column name="order_id" sql-type="char(32)"not-null="true"/> 
  12. </property> 
  13. <property name="productId" insert="false"update="false"> 
  14. <column name="product_id" sql-type="char(32)"not-null="true"/> 
  15. </property> 
  16. <property name="amount"> 
  17. <column name="amount" sql-type="int"not-null="true"/> 
  18. </property> 
  19. <property name="price"> 
  20. <column name="price" sql-type="double"not-null="true"/> 
  21. </property> 
  22. <many-to-one name="order"class="test.hibernate.Order"column="order_id" /> 
  23. <many-to-one name="product"class="test.hibernate.
    Product"
    cascade="save-update"column="product_id"/> 
  24. </class> 
  25. </hibernate-mapping> 

到目前為止,我們了解了關(guān)于<id>和<property>元素的一切,但<many-to-one>是一個(gè)新元素。這個(gè)元素非常簡單。第一個(gè)<many-to-one>元素指出OrderItem的名為order的字段是test.hibernate.Order 類型,并且通過表order_items的order_id列來引用(參見class元素的table屬性)。第二個(gè)many-to-one元素類似于第一個(gè),除了它具有cascade="save-update"屬性。它在定義的內(nèi)容之前進(jìn)行解釋。在這個(gè)例子中,我們假設(shè)Hibernate只在保存(創(chuàng)建)或更新(更改)OrderItem時(shí)傳遞Product的更改,而在刪除時(shí)不傳遞更改。因此,上述的復(fù)雜SQL語句就被壓縮為單個(gè)屬性!現(xiàn)在這個(gè)問題解決了!

【編輯推薦】

  1. Hibernate對數(shù)據(jù)索引進(jìn)行緩存
  2. 剖析Hibernate主鍵生成幾種常用方式
  3. 淺析Hibernate實(shí)現(xiàn)實(shí)體對象延遲加載
  4. Hibernate集合類型的延遲加載特性
  5. 概括Hibernate屬性延遲加載
責(zé)任編輯:佚名 來源: 51CTO.com
相關(guān)推薦

2009-09-28 15:47:59

Hibernate O

2009-09-22 09:13:43

Hibernate D

2009-09-24 13:17:37

Hibernate類庫

2009-09-29 16:46:01

創(chuàng)建Hibernate

2009-09-25 17:19:28

Hibernate持久

2009-09-27 09:55:38

Hibernate持久

2009-07-02 09:26:17

操作Hibernate

2009-06-18 11:43:40

Hibernate uHibernate s

2012-02-03 11:31:33

HibernateJava

2009-06-06 15:37:22

Hibernate性能

2009-06-26 10:01:00

Hibernate的查

2009-06-26 10:06:00

游離狀態(tài)Hibernate

2012-02-03 11:17:33

HibernateJava

2009-07-02 09:40:14

Hibernate的繼

2009-09-25 09:04:27

Hibernate類型

2012-02-08 14:24:35

HibernateJava

2009-06-12 15:05:03

cascadeHibernate

2009-06-26 16:25:43

unsaved-valHibernate

2009-09-22 10:50:04

Hibernate c

2009-09-23 09:16:25

Hibernate復(fù)合
點(diǎn)贊
收藏

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