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

被折叠的 条评论
为什么被折叠?



