ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

用JPA注解映射Set集(值类型集合)

2021-05-04 17:51:53  阅读:12  来源: 互联网

标签:CUSTOMER Customer Set 映射 JPA FILENAME IMAGES images ID


本文选自《精通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)

在这里插入图片描述

标签:CUSTOMER,Customer,Set,映射,JPA,FILENAME,IMAGES,images,ID
来源: https://blog.51cto.com/sunweiqin/2752636

专注分享技术,共同学习,共同进步。侵权联系[admin#icode9.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有