9

我在使用 javax.persistence.criteria.CriteriaBuilder 创建查询时遇到问题。我正在使用 EclipseLink 2.1 和 Oracle 10g 数据库。在构建具有多个限制的查询时,它将仅使用第一个限制,而不是两者。

这是我的代码:

CriteriaBuilder cb = getEm().getCriteriaBuilder();
CriteriaQuery<Assignment> query = cb.createQuery(Assignment.class);
Root<Assignment> assignment = query.from(Assignment.class);

query.where(
    cb.equal(assignment.get("request"), request),
    cb.isNull(assignment.get("endDate")));

return getEm().createQuery(query).getResultList();

产生的查询是:

SELECT ASSX_ID, END_DATE, BEGIN_DATE, COMMENTS, 
       ASSX_OER_ASSIGNED_TO_ID, OER_OER_ID_ASSIGNED_BY, 
       ASSX_RQST_ID 
FROM TARTS.ASSIGNMENT_XREF 
WHERE (ASSX_RQST_ID = ?)

除了 where 子句,它看起来不错。我期待:

SELECT ASSX_ID, END_DATE, BEGIN_DATE, COMMENTS, 
       ASSX_OER_ASSIGNED_TO_ID, OER_OER_ID_ASSIGNED_BY, 
       ASSX_RQST_ID FROM TARTS.ASSIGNMENT_XREF 
WHERE (ASSX_RQST_ID = ? AND BEGIN_DATE IS NOT NULL)

我是否使用 cb.and(arg1, arg2) 也没关系。难道我做错了什么?任何帮助将不胜感激。

4

1 回答 1

4

您的查询看起来完全正常。正如您所提到的,CriteriaQuery.where(Predicate... restrictions)已经使用了谓词的连词,因此无需使用 cb.and()。

我能想象的唯一的事情:

  • EclipseLink 中的错误(尝试与 Hibernate 相同)
  • 某种优化,也许endDate永远不会为空?
  • 你的 getEm() 方法做了一些奇怪的事情
于 2011-07-06T10:08:36.700 回答