1

我有以下表格:标签,员工,位置。Employee 和 Location 可以有更多标签。我认为最好为这些关系创建新表:employee_tag 和 location_tag。

如何使用 JPA 执行此操作?现在我得到了这个: 员工类:

@OneToMany()
@JoinTable(name="employee_tag", joinColumns={
    @JoinColumn(name="ID_employee", referencedColumnName="ID")
}, inverseJoinColumns={
    @JoinColumn(name="ID_tag", referencedColumnName="ID")
})
private Collection<Tag> tags;

标记类:

@ManyToOne()
private Employee employee;

它创建了一个名为employee_tag 的新表,但tag 仍然有一个employee_ID 列。如何将标签链接到此表?

4

1 回答 1

2

如果你需要一个单向的一对多关联,你不必将员工关联放在标签类中,你必须在 Employee 类中声明关联。

@Entity
public class Employee {
   @OneToMany()
   @JoinTable(name="employee_tag", joinColumns={
   @JoinColumn(name="ID_employee", referencedColumnName="ID")
   }, inverseJoinColumns={
   @JoinColumn(name="ID_tag", referencedColumnName="ID")
   })
   public Collection<Tag> tags;
   ...
}

@Entity
public class Tag {      
   ...
}

否则,您可以进行双向关联,如下所示:

@Entity
public class Employee {
   @OneToMany(mappedBy="troop")
   public Collection<Tag> tags;
   ...
}

@Entity
public class Tag {
   @ManyToOne
   @JoinColumn(name="employee_fk")
   public Employee employee;
   ...
}

看看休眠注释文档

于 2012-04-22T19:40:26.970 回答