2

我尝试使用多个映射属性。但是当我尝试运行代码时,代码会产生异常,这个例子是基于 Pro JPA 2,第 10 章的书。有以下代码:

部门ID.java

public class DeptId implements Serializable{

private static final long serialVersionUID = 5177373337405448966L;
private int number;
private String country;
    .....................

项目ID.java

public class ProjectId implements Serializable{

private static final long serialVersionUID = 4239980609226293562L;
private String name;
private DeptId deptId;
.....................

部门.java

@Entity
@IdClass(DeptId.class)
public class Department implements Serializable {

private static final long serialVersionUID = 1L;
@Id
private int number;
@Id
private String country;
private String name;

@OneToMany(mappedBy="deptId")
List<Project> projects;
    ......................

项目.java

@Entity
@IdClass(ProjectId.class)
public class Project implements Serializable {

private static final long serialVersionUID = 1L;
@Id
private String name;

@Id
@ManyToOne
@JoinColumn(name="dept_id")
private Department deptId;
    ........................

此代码将生成以下异常

Caused by: org.hibernate.AnnotationException: Implicit column reference in the @MapsId mapping fails, try to use explicit referenceColumnNames: example.domain.Department
4

1 回答 1

3

DeptID 有两个主键,所以你不能有类似@JoinColumn(name="dept_id"). 相反,使用这个:

@JoinColumns({
    @JoinColumn(name="dept_number", referencedColumnName="number"),
    @JoinColumn(name="dept_country", referencedColumnName="country")
})

如果这仍然不起作用:在主键类(DeptID 和 ProjectId)中尝试切换到公共或保护私有属性。还要检查他们是否有一个没有参数的构造函数并实现了 equals 和 hashcode 方法。

于 2013-02-01T10:13:30.580 回答