双向关系中的JPA一对一实体删除

时间:2013-03-05 09:47:44

标签: java java-ee jpa jpa-2.0

这是我的学生实体,

@Entity
@Access(AccessType.FIELD)
@Table(name="TBL_STUDENT")
public class Student  implements  Serializable{
  .....
  .....
  ....
  ..
  .
  @OneToOne(  targetEntity=StudentContact.class,
              fetch=FetchType.LAZY,
              cascade={CascadeType.ALL}
           )
  @JoinColumn(name="CONTACT_ID")
  private StudentContact contact;
  .....
  ...
  ..
}

这是我的StudentContact实体,如下所示,

@Entity
@Table(name="TBL_STD_CONTACT")
public class StudentContact implements Serializable{
   ......
   ....
   ..
   @OneToOne(  mappedBy="contact",
               targetEntity=Student.class,
               cascade={
                         CascadeType.PERSIST,
                         CascadeType.MERGE
                       }
               fetch= FetchType.LAZY)
   private Student student;
   ........
   ......
   ....
   ..
   .
}

在我的StudentTest.java中包含主要方法

这是我尝试做的事,

tx = em.getTransaction();   
tx.begin();  
StudentContact contact = em.find(StudentContact.class,38);
em.remove(contact);  
tx.commit(); 

上述操作不会删除StudentContact实体

当我检查日志时,它只显示StudentContact和Student的Select查询,

但它不打印删除查询,

它也没有显示任何异常,

我出错的地方

1 个答案:

答案 0 :(得分:2)

从Student到StudentContact可能存在参照完整性约束(外键)。因此,您无法删除StudentContact,因为学生会指向不存在的实体。

你必须首先摆脱这个引用,例如:

tx = em.getTransaction();   
tx.begin();  
StudentContact contact = em.find(StudentContact.class,38);
Student student = contact.getStudent();
student.setContact(null);
contact.setStudent(null);
em.merge(student);
em.remove(em.merge(contact));
tx.commit();