我在子对象上得到一个空引用。

让我解释:

我有两节课:

@Entity
@Table (name="CONTROLADORES")
@NamedQueries({
    @NamedQuery(name="Controlador.findAll", query="SELECT c FROM Controlador c"),
    @NamedQuery(name="Controlador.findByIdWithChilds", query="SELECT c FROM Controlador c JOIN FETCH c.cruce WHERE c.id = :id")
})
public class Controlador implements Serializable{

    private static final long serialVersionUID = -1018356240274259744L;

    @Expose
    private long id;

    @Id
        @GeneratedValue
        @GenericGenerator(name="increment", strategy = "increment")
        @Column(name="controlador_id")
    public long getId() {
        return id;
    }

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

    @OneToOne(fetch=FetchType.EAGER, cascade=CascadeType.ALL)
    @JoinColumn
    public CruceSemaforos getCruce() {
        return cruce;
    }

    public void setCruce(CruceSemaforos cruces) {
        this.cruce = cruce;
    }
}




@Entity
@Table (name="CRUCE_SEMAFOROS")
@NamedQueries({
    @NamedQuery(name="CruceSemaforos.findAll", query="SELECT c FROM CruceSemaforos c")
})
public class CruceSemaforos implements Serializable{

    /**
     *
     */
    private static final long serialVersionUID = 140756341984196420L;

    @Expose
    private long id;

    @Id
    @GeneratedValue
    @Column(name="cruce_id")
    public long getId() {
        return id;
    }

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

    private Controlador controlador;

    @OneToOne
    @JoinColumn(name="CONTROLADORES_idControlador", referencedColumnName = "controlador_id")
    public Controlador getControlador() {
        return controlador;
    }

    public void setControlador(Controlador controlador) {
        this.controlador = controlador;
    }
}


我可以创建并保留该对象的实例,并在数据库中使用正确的值设置前键(我的意思是:如果我有Controlador
在表CRUCE_SEMAFOROS中具有Cruce的控件名是在CONTROLADORS_idControlador列中设置的。

这部分工作正常。

问题是,当我尝试购买Controlador时,此类的关键装扮无效!

我认为那可能是注释错误(我在休眠注释世界中是新来的)。

请我将不胜感激任何形式的帮助!

最佳答案

对于每个双向关联,您必须选择一个且只有一个所有者方。在您的情况下,CruceSemaforos.controlador是此关联的所有者。

因此,您需要使用inverse指令将另一端声明为mappedBy

public class Controlador implements Serializable {

    ...

    @OneToOne(fetch=FetchType.EAGER, cascade=CascadeType.ALL, mappedBy = "controlador")
    public CruceSemaforos getCruce() {
        return cruce;
    }

}

09-25 19:23