List或Set <string>的JPA映射

时间:2015-08-12 13:51:27

标签: java hibernate maven jpa orm

作为ORM的新手,我想找到一种方法来定义一个简单(意味着没有额外的实体)映射实体中的一个(或一组)字符串。我找到了这个样本:

import java.util.Set;

import javax.persistence.CollectionTable;
import javax.persistence.Column;
import javax.persistence.ElementCollection;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;

@Entity
public class Book {
  @Id
  @GeneratedValue
  private Long id;

  @ElementCollection
  @CollectionTable(name = "tags")
  private Set<String> tags;

  public Long getId() {
    return id;
  }

  public void setId(Long id) {
    this.id = id;
  }

  public Set<String> getTags() {
    return tags;
  }

  public void setTags(Set<String> tags) {
    this.tags = tags;
  }
}

这似乎符合我的需要。但是,使用Eclipse的hibernate3-maven-plugin:2.2:hbm2ddl处理此类时,我最终会出现以下错误:

  

[错误]无法执行目标   org.codehaus.mojo:hibernate3-maven-plugin:2.2:hbm2ddl(默认)on   project test-database:目标的执行默认值   org.codehaus.mojo:hibernate3-maven-plugin:2.2:hbm2ddl失败:可能   不确定类型:java.util.Set,at table:Book,for columns:   [org.hibernate.mapping.Column(tags)] - &gt; [帮助1]

指定@ElementCollection(targetClass=String.class)没有帮助。将列定义添加到tags字段(@Column(name = "tags", columnDefinition="character varying (255)", nullable = false))会导致成功构建但生成此SQL:

create table Book (
    id int8 not null,
    tags character varying (255) not null,
    primary key (id)
);

这不是我想要的,因为我期望最终得到一个链接到books表的tags表。有人能指出我正确的方向吗?谢谢。

2 个答案:

答案 0 :(得分:2)

@ElementCollection已在JPA v 2.0中引入:您所做的映射是正确的。但是请确保您使用的maven hibernate插件版本正确。从版本3.5开始,Hibernate本身符合JPA 2.0。

答案 1 :(得分:0)

你应该创建一个Tag表:tag_id pk,book_id fk引用book中的id以及你想要的任何其他列 并使用以下内容列出您的列表:

@OneToMany(mappedBy="book",fetch=FetchType.LAZY, cascade=CascadeType.REMOVE)

使用数据库中的所有列创建您的标记类+一个名为book for example的Book对象,并使用以下内容映射本书:

@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="id",insertable=false,updatable=false)