一、集合类型
当实体对象的属性中集合元素时(如网购时的邮送地址),需要用到集合。常用的集合为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类型。