我正在转换到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);
由于查询在关系上没有任何选择,所以我没有进行连接。
似乎也不需要检查连接是否为空。