Maison > Java > javaDidacticiel > 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
Libérer: 2024-10-27 08:32:30
original
522 Les gens l'ont consulté

 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(...)
Copier après la connexion

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)
Copier après la connexion

Appliquant cela à l'exemple :

findByPlan_PlanTypeInAndSetupStepIsNullOrPlan_PlanTypeInAndStepupStepIs(...)
Copier après la connexion

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

(exp1) and (exp2 or exp3)
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal