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

本文介绍了使用Java持久化API (JPA)时的一些关键实践,包括如何正确地将实体合并到数据库中,避免同时获取多个集合实体时出现的错误,以及在多对一关系中删除实体的具体方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值