Представьте, что у меня есть дополнительные параметры поиска, которые могут быть нулевыми.
Есть ли более краткая альтернатива для явного проверки каждого из них, прежде чем добавлять 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 this
if (email != null) {
predicates.add(builder.equal(emailJoin.get("email"), email));
}
Он станет более уродливым, более словесным. Но так как я не очень знаком с критериями, я могу не знать о чем -то. Я бы хотел, чтобы предикат Джакарты 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 Ответы
- 10 Просмотры
-
Последнее сообщение Anonymous
-