CriteriaBuilder builder = em.getCriteriaBuilder();
CriteriaQuery cQuery = builder.createQuery();
Root<AcsTemplateDateJPA> root = cQuery.from(AcsTemplateDateJPA.class);
ParameterExpression<Date> d = builder.parameter(Date.class);
cQuery.where(builder.between(d, root.<Date>get("inservicedate"), root.<Date>get("outservicedate")));
Query query = em.createQuery(cQuery.select(root.get("acstemplateid"))).setParameter(d, planDate, TemporalType.DATE);
List results =query.getResultList();
这里的outService日期可以为null(将来无限结束) 我怎么能添加这个条件?
谢谢,
答案 0 :(得分:11)
我会将日期比较拆分为两个区块,并测试outservicedate
isNull()。类似的东西:
Predicate startPredicate = builder.greaterThanOrEqualTo(root.<Date>get("inservicedate"), d);
Path<Date> outServiceDate = root.<Date>get("outservicedate");
Predicate endPredicate = builder.or(builder.isNull(outServiceDate), builder.lessThanOrEqualTo(outServiceDate, d));
Predicate finalCondition = builder.and(startPredicate, endPredicate);
答案 1 :(得分:-2)
这应该是自我解释的:
@Override
public Predicate toPredicate( Root<OrganizationCommission> root, CriteriaQuery<?> query,
CriteriaBuilder cb )
{
// The predicate validFrom - the column should contains null or values less than validityDate
Predicate validFrom = cb.or( root.get( OrganizationCommission_.validFrom ).isNull(),
cb.lessThanOrEqualTo(
root.get( OrganizationCommission_.validFrom ),
validityDate ) );
// The predicate validTo - the column should contains null or values greater than validityDate
Predicate validTo = cb.or( root.get( OrganizationCommission_.validTo ).isNull(),
cb.greaterThanOrEqualTo( root.get( OrganizationCommission_.validTo ),
validityDate ) );
Predicate predicate = cb.conjunction();
predicate.getExpressions().add( cb.and( validFrom, validTo ) );
return predicate;
}