日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

(6) Hibernate的集合映射

發布時間:2024/1/23 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 (6) Hibernate的集合映射 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

轉載地址:?http://developer.51cto.com/art/201202/314944.htm


本文主要針對Hibernate的Set、List、Array、Map、Bag五個集合映射進行詳細的講解。


POJOs如下:
Customer類---->customer表
Order類對應---->orders表
customer(1)<----->(n)order

public class Customer { private String id; private String username; private String password; private Timestamp registerTime; private int age; private Set<Order> orders = new HashSet<Order>(); /*setter and getter method*/ }
public class Order { private String id; private String orderNumber; private int balance; private Customer customer; /*setter and getter method*/ }


Set集合映射:

Hibernate為集合映射提供了專用的標簽元素,Set集合映射,就使用<set>標簽表示:

<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping> <class name="com.suxiaolei.hibernate.pojos.Customer" table="customer"> <!-- 主鍵設置 --> <id name="id" type="string"> <column name="id"></column> <generator class="uuid"></generator> </id> <!-- 屬性設置 --> <property name="username" column="username" type="string"></property> <property name="password" column="password" type="string"></property> <property name="age" column="age" type="integer"></property> <property name="registerTime" column="register_time" type="timestamp"></property> <set name="orders" inverse="true" cascade="all"> <key column="customer_id"></key> <one-to-many class="com.suxiaolei.hibernate.pojos.Order"/> </set> </class> </hibernate-mapping>


<set>標簽中的"name"屬性表示customer對象中關系集合的屬性名,"inverse"與"cascade"屬性說明(參考這里)。
在數據庫中表示"一對多"的關系是通過外鍵關聯的方式實現的,"多方"通過持有"一方"的主鍵值來確定關系,怎么
持有"一方"的主鍵值?"多方"將使用一列來存儲"一方"的主鍵值,然后將此列作為外鍵列參照"一方"的主鍵列。
所以使用Hibernate開發時需要將兩表的關系列(外鍵列)告訴Hibernate,<key column="customer_id"></key>
就是完成這個工作的,Hibernate就能根據 "customer_id"列取出關聯信息。例如:從customer表中取出一條記錄后,
Hibernate會根據該customer記錄的主鍵值再從order表中查找"custom_id"列,取出值相等的記錄,然后組裝到
Customer對象中的set集合屬性中,反之亦然。因為取出來的記錄(只是一些零碎的值,還沒有組裝成對象)
需要存放到Set集合中,所以要告訴Hibernate在Set集合里面能放什么類型的數據。<one-to-many>這個標簽就
是完成這個工作的,"class"屬性是指定這個這個Set集合里面元素的類型。

<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping> <class name="com.suxiaolei.hibernate.pojos.Order" table="orders"> <id name="id" type="string"> <column name="id"></column> <generator class="uuid"></generator> </id> <property name="orderNumber" column="orderNumber" type="string"></property> <property name="balance" column="balance" type="integer"></property> <many-to-one name="customer" class="com.suxiaolei.hibernate.pojos.Customer"> <column name="customer_id"></column> </many-to-one> </class> </hibernate-mapping>


many-to-one>標簽是設置"一對多"關系中的"多方"的,name指定了哪一個屬性是關系屬性,"class"指定了關系屬性
的類型(也指定了與哪一個表關聯), "column"屬性是指定這個關聯屬性是按照"customer_id"列的值,在
customer表中查詢獲得的。

測試:

tx = session.beginTransaction(); /* * 創建Customer對象,并設置其屬性值 */ Customer customer = new Customer(); customer.setUsername("zhangsan"); customer.setPassword("123456"); customer.setAge(22); customer.setRegisterTime(new Timestamp(new Date().getTime())); /* * 創建Order對象order1,并設置其屬性值 */ Order order1 = new Order(); order1.setOrderNumber("a1a2a3"); order1.setBalance(1000); order1.setCustomer(customer); /* * 創建Order對象order2,并設置其屬性值 */ Order order2 = new Order(); order2.setOrderNumber("d3d2d1"); order2.setBalance(670); order2.setCustomer(customer); customer.getOrders().add(order1); customer.getOrders().add(order2); session.saveOrUpdate(customer); tx.commit();
查看數據庫的數據:

customer表


orders表?


可以看到數據被成功的插入到數據庫中了,并且"custom_id"列(關系列)也正確賦值了。


List映射:

<list name="orders" inverse="false" cascade="all"> <key column="customer_id"></key> <index column="customer_index" type="integer"></index> <one-to-many class="com.suxiaolei.hibernate.pojos.Order"/> </list>
List集合是有順序的,"index"標簽,是用于記錄順序,List的順序將表現在"customer_index"列上,
其余設置,與Set集合類似。注意:List映射中"inverse"中的值不能設置為"true",因為List集合的
順序只有customer方知道,order方不知道List的存在。不然,"customer_index"的列值將不會被賦值。

查看數據庫:
customer表:


orders表:


可以看到記錄正確的插入到數據庫中了,而且"custom_index"正確的表示出List的順序。
Array(數組)映射:標簽使用<array>其他與List基本一致。

Map映射:

Hibernate為集合映射提供了專用的標簽元素,Map集合映射,就使用<map>標簽表示:

<map name="orders" inverse="false" cascade="all"> <key column="customer_id"></key> <index column="order_key" type="string"></index> <one-to-many class="com.suxiaolei.hibernate.pojos.Order"/> </map>Map映射中<index>標簽,表示Map集合中的key值,記錄在"order_key"列中,<one-to-many>表示Map集合中的vlaue。
其他設置與上面一樣。注意:"inverse"不要設置成"true"因為key值是customer對象維護的,而order不知道key的
存在。


Bag映射:

它是List與Set集合的結合,可以重復,但是無順。使用List模擬Bag。設置類似Set,它也有專用標簽<bag>。


總 ?結

在沒有特殊要求下,最好使用Set集合,因為Set集合沒有特殊信息需要"一方"自己維護,可以完全交給"多方"維護,
能夠提高性能,若需要記錄數據的順序可以使用List和Array映射,若需要key/value形式存儲數據,可以使用Map
映射。最后一點若集合放置的數據簡單類型(原生類型、原生類型的包裝類、String、Date之類的)在集合映射配置
上稍有不同,<element>元素可以直接映射這些簡單類型,其他配置與上述配置沒什么不同。


總結

以上是生活随笔為你收集整理的(6) Hibernate的集合映射的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。