本文选自《精通JPA与Hibernate:Java对象持久化技术详解》,清华大学出版社出版,作者孙卫琴
假定Customer对象的images集合中不允许存放重复的照片文件名,因此可以把images属性定义为Set类型:
private Set<String> images=new HashSet<String>();
在数据库中定义了一张IMAGES表,它的CUSTOMER_ID字段为参照CUSTOMERS表的外键,由于Customer对象不允许有重复的照片文件名,因此应该把IMAGES表的CUSTOMER_ID和FILENAME字段作为联合主键。
以下是IMAGES表的DDL定义:
create table IMAGES(
CUSTOMER_ID bigint not null,
FILENAME varchar(15) not null,
primary key (CUSTOMER_ID,FILENAME),
foreign key (CUSTOMER_ID) references CUSTOMERS(ID)
);
在Customer类中,映射Customer类的images属性的代码如下:
@ElementCollection
@CollectionTable(name="IMAGES",
joinColumns=@JoinColumn(name="CUSTOMER_ID"))
@Column(name="FILENAME")
private Set<String> images=new HashSet<String>();
@ElementCollection注解用于映射集合类型images属性,@CollectionTable注解指定images集合对应IMAGES数据库表,joinColumns属性指定IMAGES表的CUSTOMER_ID外键参照CUSTOMERS主表。@Column注解指定images集合中的每个元素对应IMAGES表的FILENAME字段。
默认情况下,对Customer对象的images属性采用延迟检索策略。如果需要采用立即检索策略,可以通过@ElementCollection注解的fetch属性来设定:
@ElementCollection(fetch=FetchType.EAGER)