让我们假设以下情况:我有两个实体类 Person 和 Comment。
//Person class
@Entity
public class Person extends AbstractBusinesObject{
@OneToMany(mappedby ="owner")
private List<Comment> comments;
//Comment class
@Entity
public class Comment extends AbstractBusinesObject{
@ManyToOne
private Person owner;
我想从以下两种选择中了解哪种方法更好(性能,内存效率),以确定特定评论是否属于特定人。
public boolean isUsersComment(Person p, Comment c){
return p.getComments().contains(c);
}
或者
public boolean isUsersComment(Person p, Comment c){
CriteriaBuilder cb = getEntitymanager().getCriteriaBuilder();
CriteriaQuery<Comment> cq = cb.createQuery(Comment.class);
Root<Comment> root = cq.from(Comment.class);
cq.select(root).where(cb.and(cb.equal(root, c), cb.isTrue(root.in(p.getComments())));
try{
getEntityManager().createQuery(cq).getSingleResult();
return true;
} catch (NoResultException ex){
return false;
} catch (NoUniqueResultException ex){
throw new IllegalStateException(message);
}
}
据我所知,criteria api 生成一个数据库查询,而第一个解决方案在集合中搜索。
谢谢您的回答。
ps:我是 Criteria API 的新手,所以我也接受修复/建议。
编辑
好的,我发现这是一个愚蠢的问题;正如我声明的双向关系,解决方案非常简单:
return c.getOwner.equals(p);
无论如何,单向关系的方法是什么?