有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java多通原因未映射到单个属性

我得到了以下例外:

Failed to create sessionFactory object.org.hibernate.AnnotationException: referencedColumnNames(wojid_fk, powid_fk, id, rodzgm_fk) of com.darek.Persistance.teryt.Miejscowosc.gmina referencing com.darek.Persistance.teryt.Gmina not mapped to a single property

这是我的Miejscowosc课程:

//imports
(...)

@Entity
@Table(name = "miejscowosc")
public class Miejscowosc {

    public Miejscowosc(int id, String nazwa, boolean nazwazwyczajowa,
            RodzajMiejscowosci rodzmiejsc, Gmina gmina, int idpod, Date stanna) {
        super();
        this.id = id;
        this.nazwa = nazwa;
        this.nazwazwyczajowa = nazwazwyczajowa;
        this.stanna = stanna;
        this.rodzmiejsc = rodzmiejsc;
        this.gmina = gmina;
        this.idpod = idpod;
        }

protected Miejscowosc() {
    super();
}

@Id
@Column(columnDefinition = "MEDIUMINT(7)")
private int id;

@Column(columnDefinition = "MEDIUMINT(7)")
private int idpod;

@Column(columnDefinition = "CHAR(36)")
private String nazwa;

@Column(name = "nazwazwyczajowa", columnDefinition = "BIT", length = 1)
private boolean nazwazwyczajowa;

@Column(columnDefinition = "DATE")
private Date stanna;

@JoinColumn(name = "rodzmiejsc_fk", referencedColumnName = "id")
@ManyToOne
private RodzajMiejscowosci rodzmiejsc;

@JoinColumns({
        @JoinColumn(name = "wojid_fk", referencedColumnName = "wojid_fk"),
        @JoinColumn(name = "powid_fk", referencedColumnName = "powid_fk"),
        @JoinColumn(name = "gmid_fk", referencedColumnName = "id"),
        @JoinColumn(name = "rodzgm_fk", referencedColumnName = "rodzgm_fk") })
@ManyToOne
private Gmina gmina;


//getters and setters
(...)

}

这就是我的Gmina课程:

//imports
(...)
@SuppressWarnings("unused")
@Entity
@Table(name = "gmina")
public class Gmina {

public Gmina(int id, String nazwa, String nazwadod, Date stanna) {
    super();
    this.id = id;
    this.nazwadod = nazwadod;
    this.nazwa = nazwa;
    this.stanna = stanna;
}

protected Gmina() {
    super();
}

@Id
@Column(columnDefinition = "SMALLINT")
private int id;

@Column(columnDefinition = "CHAR(50)")
private String nazwadod;

@Column(columnDefinition = "CHAR(36)")
private String nazwa;

@Column(columnDefinition = "DATE")
private Date stanna;

@JoinColumns({
        @JoinColumn(name = "powid_fk", referencedColumnName = "id", insertable = false, updatable = false),
        @JoinColumn(name = "wojid_fk", referencedColumnName = "wojid_fk", insertable = false, updatable = false) })
@ManyToOne
private Powiat powiat;

@ManyToOne
@JoinColumn(name = "rodzgm_fk", referencedColumnName = "id", insertable = false, updatable = false)
private RodzajGminy rodzGm;

//getters and setters
(...)

}

我如何解决这个问题?为什么会存在这个问题? 提前感谢您的帮助

编辑:

gmina表和miejscowosc表都有wojid_fkpowid_fkrodzgm_fk列,这就是我使用它们相同名称的原因。唯一的区别是gmina有id,而miejscowosc有gmid_-fk(id的外键)


共 (1) 个答案

  1. # 1 楼答案

    你需要像下面这样使用@JoinColumns

    @JoinColumns({    
      @JoinColumn(name = "first", referencedColumnName = "column_name"),
      @JoinColumn(name = "second", referencedColumnName = "column_name"),
      @JoinColumn(name = "third", referencedColumnName = "column_name")
    })