Spring数据jpa条件查询重构

时间:2018-05-27 06:24:28

标签: java spring-data-jpa specifications criteria-api

我在spring数据jpa项目中有一段代码我需要重构。实际上我想减少if方法这个方法的阶梯。

private static void buildEntitlementFilterQuery(Root<Entitlement> entitlement, CriteriaBuilder cb,
        List<Predicate> predicates, Entry<String, String> entry) {

    if (StringUtils.isNotBlank(entry.getValue())) {
        if (entry.getKey().equalsIgnoreCase(Constants.START_DATE)) {
            predicates.add(cb.and(cb.greaterThanOrEqualTo(entitlement.get(entry.getKey()),
                    DateUtil.convertString(entry.getValue()))));
        } else if (entry.getKey().equalsIgnoreCase(Constants.END_DATE)) {
            predicates.add(cb.and(cb.lessThanOrEqualTo(entitlement.get(entry.getKey()),
                    DateUtil.convertString(entry.getValue()))));
        } else if (entry.getKey().equalsIgnoreCase(Constants.QNT_GRANTED)) {
            predicates.add(cb.and(cb.greaterThan(entitlement.get(entry.getKey()), entry.getValue())));
        } else if (entry.getKey().equalsIgnoreCase(Constants.VALUE_GRANTED)) {
            predicates.add(cb.and(cb.greaterThan(entitlement.get(entry.getKey()), entry.getValue())));
        } else if (StringUtils.contains(entry.getValue(), Constants.COMMA)) {
            predicates.add(
                    cb.and(entitlement.get(entry.getKey()).in(Arrays.asList(StringUtils.split(entry.getValue())))));
        } else {
            predicates.add(cb.and(cb.equal(entitlement.get(entry.getKey()), entry.getValue())));
        }
    }
}

或者我必须为每个操作制作每个方法?有什么建议吗?

0 个答案:

没有答案