Представьте, что у меня есть дополнительные параметры поиска, которые могут быть нулевыми.
Есть ли более краткая альтернатива для явного проверки каждого из них, прежде чем добавлять Jakarta.persistence.criteria.fedicate в какой -то локальный список ? Pretty): < /p>
import org.springframework.data.jpa.domain.Specification;
//...
private static Specification buildSpecification(FindUserRequestDto userRequestDto) {
return (root, query, criteriaBuilder) -> {
var nameBeginsWith = criteriaBuilder.like(root.get("name"), userRequestDto.getName() + "%");
var ageGreaterThan = criteriaBuilder.greaterThan(root.get("dateOfBirth"), userRequestDto.getDateOfBirth());
var hasEmail = criteriaBuilder.equal(root.join("emailData").get("email"), userRequestDto.getEmail());
var hasPhone = criteriaBuilder.equal(root.join("phoneData").get("phone"), userRequestDto.getPhone());
return criteriaBuilder.and(nameBeginsWith, ageGreaterThan, hasEmail, hasPhone);
Но если я представлю явную null проверьте для каждого дополнительного параметра, он станет более уродливым, более словесным.// like so
private static Specification buildSpecification(FindUserRequestDto userRequestDto) {
return (root, query, criteriaBuilder) -> {
var nameBeginsWith = criteriaBuilder.like(root.get("name"), userRequestDto.getName() + "%");
var bornAfter = criteriaBuilder.greaterThan(root.get("dateOfBirth"), userRequestDto.getDateOfBirth());
var hasEmail = criteriaBuilder.equal(root.join("emailData").get("email"), userRequestDto.getEmail());
var hasPhone = criteriaBuilder.equal(root.join("phoneData").get("phone"), userRequestDto.getPhone());
List predicates = new ArrayList();
if (userRequestDto.getName() != null) predicates.add(nameBeginsWith);
if (userRequestDto.getDateOfBirth() != null) predicates.add(bornAfter);
if (userRequestDto.getEmail() != null) predicates.add(hasEmail);
if (userRequestDto.getPhone() != null) predicates.add(hasPhone);
return criteriaBuilder.and(predicates.toArray(new jakarta.persistence.criteria.Predicate[0]));
};
}
Вы можете утверждать, что это потерянное дело, чтобы попытаться составить критерии не условно и некрасиво. Но так как я не очень знаком с критериями, я могу не знать о чем -то. Я бы хотел, чтобы предикат Джакарты s имел некоторые или () метод.
Вот мои (упрощенные) сущности:
import jakarta.persistence.CascadeType;
import jakarta.persistence.Column;
import jakarta.persistence.Entity;
import jakarta.persistence.FetchType;
import jakarta.persistence.GeneratedValue;
import jakarta.persistence.GenerationType;
import jakarta.persistence.Id;
import jakarta.persistence.OneToMany;
import jakarta.persistence.Table;
import lombok.Getter;
import lombok.Setter;
import java.util.List;
@Entity
@Getter
@Setter
@Table(name = "\"user\"")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
private String name;
@OneToOne(mappedBy = "user")
@OneToMany(mappedBy = "user", fetch = FetchType.EAGER,
cascade = CascadeType.ALL, orphanRemoval = true)
private List emailData;
}
< /code>
import jakarta.persistence.Entity;
import jakarta.persistence.GeneratedValue;
import jakarta.persistence.GenerationType;
import jakarta.persistence.Id;
import jakarta.persistence.JoinColumn;
import jakarta.persistence.ManyToOne;
import jakarta.persistence.Table;
import lombok.Getter;
import lombok.Setter;
@Entity
@Getter
@Setter
@Table(name = "email_data")
public class EmailData {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@ManyToOne
@JoinColumn(name = "user_id")
private User user;
private String email;
}
Подробнее здесь: https://stackoverflow.com/questions/796 ... iteria-api
Обработка необязательных параметров поиска в API -критериях ⇐ JAVA
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Устареть обязательных параметров после необязательных параметров в функции/методе.
Anonymous » » в форуме Php - 0 Ответы
- 9 Просмотры
-
Последнее сообщение Anonymous
-