Hibernate学习——第二章

来源:互联网 发布:java写入excel换行 编辑:程序博客网 时间:2024/06/05 06:02

一、集合类型

当实体对象的属性中集合元素时(如网购时的邮送地址),需要用到集合。常用的集合为list、set、map。

  • list集合。list集合有序,内容可重复。
  • set集合。hashset为无序,不可重复;treeset和linkedset为有序的集合。set集合最为常用。
  • map集合。需要键值对,键值不能重复。

1、set集合在*.hbm.xml中的配置

<set name="addressSet" table="user_address">    <key column="userId"></key>    <element column="address" type="string"></element></set>

name属性为实体对象中该集合的属性名;table指定一个集合表,表名为user_address;key为外键,指向原表中的主键,在集合表中该列名为userId;element为存储信息的列,必须指定type类型。
此为hashset的写法,hashSet无序。

若在set标签中添加sort属性(值为unsorted|natural|compareClass,默认为unsorted无序),此时可排序,但是此种排序是在内存中排序(不能为hashset),不建议使用。

<set name="addressOrderBySet" table="user_addressOrderBySet"     order-by="address desc">    <key column="userId"></key>    <element type="string" column="address"></element></set>

若在set标签中使用order-by属性,指定排序的列和排序方法(desc降序,asc升序),则可实现sql语句排序。

2、list集合在*.hbm.xml中的配置

<list name="addressList" table="user_addressList">    <key column="userId"></key>    <list-index column="idx"></list-index>    <element type="string" column="address"></element></list>

name属性为实体对象中该集合的属性名;table指定一个集合表,表名为user_addressList;key为外键,指向原表中的主键,在集合表中该列名为userId;element为存储信息的列,必须指定type类型;list是有序的,因此还需要有索引,list-index即为索引。

3、map集合在*.hbm.xml中的配置

<map name="addressMap" table="user_addressMap">    <key column="userId"></key>    <map-key type="string" column="key_"></map-key>    <element type="string" column="address"></element></map>

name属性为实体对象中该集合的属性名;table指定一个集合表,表名为user_addressMap;key为外键,指向原表中的主键,在集合表中该列名为userId;element为存储信息的列,必须指定type类型;map需要有键值,map-key即为键值,必须指定type类型。

0 0
原创粉丝点击