EclipseLink删除引用的实体

时间:2011-05-27 12:56:37

标签: jpa 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;    
}

1 个答案:

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