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!