我在子对象上得到一个空引用。
让我解释:
我有两节课:
@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;
}
}