Мне нужно создать предикат для извлечения данных из таблицы, где regId = ? (||) or (&&) estCode = ? && latest (referralEntryDate)
Генерирование предикат последнего значения даты
получать данные для последней даты
@Override
public Predicate toPredicate(Root<ReviewMedicalStatus> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
List<Predicate> predicatesReg = new ArrayList<Predicate>();
if (revStatusDto.getRegId() != null && !StringUtils.isEmpty(revStatusDto.getRegId())) {
predicatesReg.add(cb.equal(root.get("regId"), revStatusDto.getRegId()));
}
if (revStatusDto.getEstCode() != null && !StringUtils.isEmpty(revStatusDto.getEstCode())) {
predicatesReg.add(cb.equal(root.get("estCode"), revStatusDto.getEstCode()));
}
Expression maxExpression = cb.max(root.get("referralEntryDate"));
predicatesReg.add(maxExpression);
//predicatesReg.add(cb.max(root.get("referralEntryDate")));
return cb.and(predicatesReg.toArray(new Predicate[predicatesReg.size()]));
}
Это не удается, поскольку выражение не может быть передается как параметр для предиката. Как я могу получить данные для последних referralEntryDate
?