ホームページ >Java >&#&チュートリアル >Spring Data JPA 仕様は、構成可能な AND 句を使用した動的クエリをどのように解決できますか?
構成可能な AND 句を使用した動的 Spring Data JPA リポジトリ クエリ
Spring Data JPA では、ユーザー提供の入力に基づいて調整されたクエリを構築できます。特にオプションの検索フィールドを扱う場合は困難です。この記事では、仕様を使用した最適なソリューションを検討します。
既存のアプローチの制限
Spring Data のサンプルによるクエリ (QBE) アプローチと Querydsl の両方には、オプションのフィールドの処理に制限があります。さまざまなフィールドの組み合わせに対して複数のクエリを手動でコーディングする必要があります。これは、検索フィールドの数が増えると現実的ではなくなります。
解決策: 仕様の使用
Spring Data 仕様は、基準クエリを動的に構築する拡張可能な方法を提供します。これらを使用すると、組み合わせて複雑なクエリを形成できる再利用可能な条件式を作成できます。
仕様を利用するには、JpaSpecificExecutor を使用してリポジトリ インターフェイスを拡張します。
public interface CustomerRepository extends SimpleJpaRepository<T, ID>, JpaSpecificationExecutor { }
仕様インターフェイスは、toPredicate メソッドを定義します。クエリの CriteriaBuilder に適用する述語を作成しますBuilding.
public interface Specification<T> { Predicate toPredicate(Root<T> root, CriteriaQuery<?> query, CriteriaBuilder builder); }
たとえば、次のようなユースケースがあるとします。isLongTermCustomer や hasSalesOfMoreThan などのオプションの基準を使用した顧客検索です。これらの基準の仕様を定義し、and or or を使用してそれらを組み合わせることができます。
public class CustomerSpecs { public static Specification<Customer> isLongTermCustomer() {...} public static Specification<Customer> hasSalesOfMoreThan(MonetaryAmount value) {...} } List customers = customerRepository.findAll(isLongTermCustomer()); List customers = customerRepository.findAll(where(isLongTermCustomer()).or(hasSalesOfMoreThan(amount)));
複雑な仕様
仕様を連鎖させて組み合わせて、複雑な基準を作成できます。たとえば、次の仕様では、機能、エピック、グループ、日付、チームなどの検索条件に基づいて進行中の作業が検索されます。
public class WorkInProgressSpecification { public static Specification<WorkInProgress> findByCriteria(final SearchCriteria searchCriteria) {...} }
結論
仕様オプションのフィールドを使用して動的な Spring Data JPA クエリを構築するための強力でスケーラブルなソリューションを提供します。これらにより、柔軟な基準の組み合わせが可能になり、再利用可能な述語式の作成が可能になります。
以上がSpring Data JPA 仕様は、構成可能な AND 句を使用した動的クエリをどのように解決できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。