我正在使用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;
}
答案 0 :(得分:0)
我不确定我是否清楚这个问题 - 当你调用remove(type)时你是否期待异常?如果是这样,请检查您是否在Device-> Type关系上设置了数据库约束,这将在删除时抛出异常。表格是如何创建的?
如果问题是你得到一个例外 - 因为你不应该先删除一个实体而不清除对它的引用。在删除之前,应查询设备并修复对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设置回设备。