Hibernate CriteriaQuery检查空连接



我正在转换到hibernate 5.2.4并使用CriteriaQuery。在测试文件上的空连接时有一个小问题。这是我之前所做的工作。

@Entity
public class MyClass {
 ....
 @ManyToOne(..)
 public MyDetail getMyDetail() { 
  return myDetail;  
 }
}
Criteria criteria = session.createCriteria(MyClass.class);
criteria.createAlias("myDetail", "md");
criteria.add(Restrictions.isNotNull("myDetail"));

我一直在这样检查,有时它不工作:

andPredicate = builder.and(andPredicate, builder.isNotNull(
                    root.get(MyClass_.myDetail)));

有正确的方法来做这件事吗?我尝试创建连接并测试null,但这也不起作用:

Join<MyClass, MyDetail> myJoin = root.join(MyClass_.myDetail);
andPredicate = builder.and(andPredicate, myJoin.isNotNull());

谢谢。

算出来了,我需要一个匹配的

criteria.createAlias("myDetail", "md");
ie:

root.join(MyClass_.myDetail);

由于查询在关系上没有任何选择,所以我没有进行连接。

似乎也不需要检查连接是否为空。

相关内容

  • 没有找到相关文章

最新更新