Rumah >Java >javaTutorial >Bagaimana untuk Membina Pertanyaan JPA Data Spring Dinamik dengan Kriteria Penapis Pilihan?
Pertanyaan Repositori JPA Data Spring Dinamik dengan Kriteria Penapis Pilihan
Masalah:
Pada Musim Bunga JPA Data, menjana pertanyaan dinamik dengan kriteria penapis pilihan menjadi mencabar apabila bilangan medan meningkat, membawa kepada sejumlah besar pertanyaan statik yang perlu ditulis secara manual.
Pendekatan Terbaik: API Spesifikasi dan Kriteria
Spring Data JPA menyediakan antara muka Spesifikasi dan API Kriteria untuk menangani isu ini. Spesifikasi membolehkan penciptaan predikat terprogram yang boleh digabungkan secara dinamik dan digunakan untuk membina pertanyaan.
Melaksanakan Spesifikasi
Untuk menggunakan Spesifikasi, lanjutkan antara muka repositori dengan JpaSpecificationExecutor antara muka:
public interface EmployeeRepository extends JpaRepository<Employee, Integer>, JpaSpecificationExecutor<Employee> {}
Mencipta a Spesifikasi
Buat kelas Java yang melaksanakan antara muka Spesifikasi, mentakrifkan logik predikat untuk setiap kriteria penapis. Contohnya, untuk mencipta spesifikasi bagi medan Nombor Pekerja:
public class EmployeeNumberSpecification implements Specification<Employee> { private String employeeNumber; public EmployeeNumberSpecification(String employeeNumber) { this.employeeNumber = employeeNumber; } @Override public Predicate toPredicate(Root<Employee> root, CriteriaQuery<?> query, CriteriaBuilder builder) { if (employeeNumber == null || employeeNumber.isEmpty()) { return builder.disjunction(); // Allow any value } return builder.like(root.get("employeeNumber"), "%" + employeeNumber + "%"); } }
Menggabungkan Spesifikasi
Berbilang spesifikasi boleh digabungkan menggunakan operator logik (cth., dan, atau, bukan) untuk mencipta kriteria carian yang lebih kompleks. Contohnya, untuk mencari pekerja dengan Nombor Pekerja dan Profesion tertentu:
Specification<Employee> employeeNumberSpec = new EmployeeNumberSpecification("10"); Specification<Employee> professionSpec = new ProfessionSpecification("IT"); Specification<Employee> combinedSpec = Specification.where(employeeNumberSpec).and(professionSpec);
Melaksanakan Pertanyaan
Spesifikasi boleh digunakan dengan findAll dan kaedah lain JPA repositori untuk melaksanakan dinamik pertanyaan:
List<Employee> employees = employeeRepository.findAll(combinedSpec);
Faedah Spesifikasi:
Atas ialah kandungan terperinci Bagaimana untuk Membina Pertanyaan JPA Data Spring Dinamik dengan Kriteria Penapis Pilihan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!