Maison  >  Article  >  Java  >  Spring Data JPA peut-il gérer des requêtes complexes avec des opérateurs combinés « Et » et « Ou » ?

Spring Data JPA peut-il gérer des requêtes complexes avec des opérateurs combinés « Et » et « Ou » ?

DDD
DDDoriginal
2024-10-27 08:32:30369parcourir

 Can Spring Data JPA Handle Complex Queries with Combined

Création de requêtes complexes avec des opérateurs logiques combinés dans Spring Data JPA

Améliorant les capacités de création de requêtes intuitives de Spring Data JPA, cette question est aux prises avec combinant les opérateurs "Et" et "Ou" via des noms de méthodes. Pour y parvenir, la méthode de requête est conçue comme suit :

findByPlan_PlanTypeInAndSetupStepIsNullOrStepupStepIs(...)

Cependant, la requête résultante interprète l'expression comme [(exp1 et exp2) ou (exp3)], en conflit avec le ](exp1) prévu. et (exp2 ou exp3)].

Spring Data JPA peut-il prendre en charge des requêtes aussi complexes ?

Solution : exploiter l'équivalence logique

Bien qu'il soit prudent de évitez les noms de méthodes trop longs et incompréhensibles, le résultat souhaité peut être obtenu en tirant parti de l'équivalence logique suivante :

A /\ (B \/ C) <=> (A /\ B) \/ (A /\ C)
A and (B or C) <=> (A and B) or (A and C)

Appliquant cela à l'exemple :

findByPlan_PlanTypeInAndSetupStepIsNullOrPlan_PlanTypeInAndStepupStepIs(...)

En séparant les expressions en Plan_PlanTypeInAndSetupStepIsNull et Plan_PlanTypeInAndStepupStepIs, nous pouvons construire la requête correcte :

(exp1) and (exp2 or exp3)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn