如何解决EclipseLink删除引用的实体
| 我正在使用EclipseLink作为我的持久性单元。我在删除实体时遇到问题。以下示例:设备具有类型。有许多设备可能具有相同的类型。 我插入了视图类型和设备(指的是一种类型)。如果现在删除一种类型(设备引用),则该实体将从数据库中删除。这不应该发生,因为设备引用了该类型。 我做错了什么? 提前致谢! 我正在删除以下内容:EntityManager em = factory.createEntityManager();
em.getTransaction().begin();
Query q = em.createQuery(\"SELECT d FROM DeviceType d WHERE d.name = :name\");
q.setParameter(\"name\",\"Name\");
Type type = (Type)q.getSingleResult();
em.remove(type);
em.getTransaction().commit();
em.close();
我的实体:
@Entity
public class Device {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@OneToOne
@JoinColumn(name=\"TYPE_ID\",nullable = false)
private Type type;
}
@Entity
public class Type {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(unique = true,nullable = false)
private String name;
}
解决方法
我不确定我是否很清楚这个问题-调用remove(type)时是否期望异常?如果是这样,请检查是否在Device-> Type关系上设置了数据库约束,这将在删除时引发异常。表格如何创建?
如果问题出在您的身上,那是一个异常-这是因为您不应该先删除对实体的引用就不要删除该实体。应该在删除设备之前查询设备并修复对该类型的任何引用,即:
Query q = em.createQuery(\"SELECT device FROM Type device WHERE device.type.name :name\");
q.setParameter(\"name\",\"Name\");
List devices = q.getResultList();
集合中每个返回的设备都应引用相同的类型实例,因此您可以在以后将其删除。如果希望能够从类型实例访问它们,也可以将映射更改为ManyToOne,然后将Type中的OneToMany设置回设备。