net.kaczmarzyk.spring.data.jpa.domain.Between Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of specification-arg-resolver Show documentation
Show all versions of specification-arg-resolver Show documentation
An alternative API for filtering data with Spring MVC and Spring Data JPA.
This library provides a custom HandlerMethodArgumentResolver that transforms HTTP parameters
into a Specification object ready to use with Spring Data repositories.
/**
* Copyright 2014-2020 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.kaczmarzyk.spring.data.jpa.domain;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Expression;
import javax.persistence.criteria.Predicate;
import javax.persistence.criteria.Root;
import net.kaczmarzyk.spring.data.jpa.utils.Converter;
import net.kaczmarzyk.spring.data.jpa.utils.QueryContext;
import java.util.Objects;
/**
* Filters with {@code path between arg1 and arg2} where-clause.
*
* Supports multiple field types: strings, numbers, booleans, enums, dates.
*
* Field types must be Comparable (e.g, implement the Comparable interface); this is
* a JPA constraint.
*
* NOTE: comparisons are dependent on the underlying database.
* Comparisons of floats and doubles (especially floats) may be incorrect due to precision loss.
* Comparisons of booleans may be dependent on the underlying database representation.
* Comparisons of enums will be of their ordinal or string representations, depending on what you specified to JPA,
* e.g., {@code @Enumerated(EnumType.STRING)}, {@code @Enumerated(EnumType.ORDINAL)} or the default ({@code @Enumerated(EnumType.ORDINAL)})
*
* @author Tomasz Kaczmarzyk
* @author TP Diffenbach
*/
public class Between extends PathSpecification {
private static final long serialVersionUID = 1L;
private final String lowerBoundaryStr;
private final String upperBoundaryStr;
private final Converter converter;
public Between(QueryContext queryContext, String path, String[] args, Converter converter) {
super(queryContext, path);
if (args == null || args.length != 2) {
throw new IllegalArgumentException("expected 2 http params (lower and upper boundaries), but was: " + args);
}
this.converter = converter;
this.lowerBoundaryStr = args[0];
this.upperBoundaryStr = args[1];
}
@SuppressWarnings("unchecked")
@Override
public Predicate toPredicate(Root root, CriteriaQuery> query, CriteriaBuilder criteriaBuilder) {
Expression> targetExpression = path(root);
Class> typeOnPath = targetExpression.getJavaType();
Comparable
© 2015 - 2024 Weber Informatics LLC | Privacy Policy