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;
  }
 }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值