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设置回设备。     

要回复问题请先登录注册