Merge,FetchType,多对一关系的删除

1.当一个实体存在,要建立另一个实体,那个实体把这个实体作为其一属性,则应用merge方法加到数据库中,用persist会出错

2.在用JPA进行注释时,如果一个实体里要映射多个集合实体时,我们不能把两个集合的的FetchType设置为EAGER,此时只能设置为LAZY,否则会报:cannot simultaneously fetch multiple bags。或者我们也可以借助:@IndexColumn

3.多对一关系的删除
public boolean removeContactPerson(int cid)
 {
  try
  {
   /*Query q = em.createQuery("select cper from ContactPerson cper where cper.CID =:cid_param")
      .setParameter("cid_param", cid);
   //q.executeUpdate();
   ContactPerson cper = (ContactPerson)q.getSingleResult();
   em.remove(cper);
   return true;*/
   
   Query q = em.createQuery("delete from ContactPerson cper where cper.CID =:cid_param")
   .setParameter("cid_param", cid);
   q.executeUpdate();
   
   return true;
   
   
   
   
   /*ContactPerson cper  = em.find(ContactPerson.class, cid);
   System.out.print("remove" + cid);
   em.remove(cper);
   return true;*/
  }
  catch(Exception e)
  {
   return false;
  }
 }

你可能感兴趣的:(jpa)