假定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)

该博客讨论了如何在Java中使用`@ElementCollection`注解将对象的集合属性映射到数据库表,确保数据的唯一性。通过定义联合主键,确保了IMAGES表的CUSTOMER_ID和FILENAME字段的不重复性。同时,展示了如何设置延迟检索和立即检索策略,以优化数据访问性能。
243

被折叠的 条评论
为什么被折叠?



