首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >列表或Set<String>的JPA映射

列表或Set<String>的JPA映射
EN

Stack Overflow用户
提问于 2015-08-12 13:51:27
回答 2查看 15K关注 0票数 7

对于ORM来说,我想找到一种方法来定义一个简单的(意思是没有附加实体的)映射到一个实体中的一个列表(或一组)字符串。我发现了这个样本:

代码语言:javascript
复制
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 (默认)-数据库:目标org.codehaus.mojo:hibernate3-maven-plugin:2.2:hbm2ddl的执行默认失败:无法确定类型为: java.util.Set,at table: Book,for org.hibernate.mapping.Column(标记) ->帮助1

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

代码语言:javascript
复制
create table Book (
    id int8 not null,
    tags character varying (255) not null,
    primary key (id)
);

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

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-08-12 15:28:21

@ElementCollection已经在JPAv2.0中引入:您所做的映射是正确的。但是,请确保您使用的maven hibernate插件的版本是正确的。Hibernate本身与JPA2.0兼容,从3.5版开始。

票数 4
EN

Stack Overflow用户

发布于 2015-08-12 14:19:14

您应该创建一个标记表: tag_id pk,book_id fk引用,从书和任何其他您想要的列中获得id,并用如下所示的方式映射您的列表:

代码语言:javascript
复制
@OneToMany(mappedBy="book",fetch=FetchType.LAZY, cascade=CascadeType.REMOVE)

使用database+中的所有列创建标记类,一个名为Book的book作为示例,并将这本书映射为:

代码语言:javascript
复制
@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="id",insertable=false,updatable=false)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31967221

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档