IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JPA Java Discussion :

Requête JPQL avec MINUS


Sujet :

JPA Java

  1. #1
    Membre habitué Avatar de JacNar6
    Homme Profil pro
    Développeur Java/Java EE/Android
    Inscrit en
    Mai 2012
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Java/Java EE/Android

    Informations forums :
    Inscription : Mai 2012
    Messages : 163
    Points : 134
    Points
    134
    Par défaut Requête JPQL avec MINUS
    Bonjour,

    J'aimerais savoir s'il est possible de faire une requête JPA avec MINUS ou un équivalent ?

    Prenons par exemple le cas d'une modélisation où une personne (t_personne) exerce plusieurs activités (t_activite). Comment écrire une requête JPQL qui me retournera les personnes n'ayant pas d'activité (chaque enregistrement dans la table Activité contenant une clé étrangère désignant la personne concernée).

    Une requête native ne pose bien évidemment aucun problème.

    Merci d'avance pour votre aide.
    Si vous avez de l'Amour, vous ne ferez du mal à personne et personne ne vous fera du mal. W M Branham

  2. #2
    Membre confirmé Avatar de bruneltouopi
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2010
    Messages
    308
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2010
    Messages : 308
    Points : 466
    Points
    466
    Par défaut
    Postes le code de tes entités.
    Ce qui ne me tue pas me rend plus fort.

  3. #3
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3 274
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3 274
    Points : 4 141
    Points
    4 141
    Par défaut
    Un not exists devrait faire l'affaire, non ?

  4. #4
    Membre habitué Avatar de JacNar6
    Homme Profil pro
    Développeur Java/Java EE/Android
    Inscrit en
    Mai 2012
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Java/Java EE/Android

    Informations forums :
    Inscription : Mai 2012
    Messages : 163
    Points : 134
    Points
    134
    Par défaut
    Citation Envoyé par fr1man Voir le message
    Un not exists devrait faire l'affaire, non ?
    Pardon pour ma réaction tardive; Comment faire cela avec not exists
    Si vous avez de l'Amour, vous ne ferez du mal à personne et personne ne vous fera du mal. W M Branham

  5. #5
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3 274
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3 274
    Points : 4 141
    Points
    4 141
    Par défaut
    Un truc du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    select p from Personne
    where not exists (
      select a from Activite where a.personne = p
    )

  6. #6
    Membre habitué Avatar de JacNar6
    Homme Profil pro
    Développeur Java/Java EE/Android
    Inscrit en
    Mai 2012
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Java/Java EE/Android

    Informations forums :
    Inscription : Mai 2012
    Messages : 163
    Points : 134
    Points
    134
    Par défaut
    Ok! Je teste tout de suite
    Si vous avez de l'Amour, vous ne ferez du mal à personne et personne ne vous fera du mal. W M Branham

  7. #7
    Membre habitué Avatar de JacNar6
    Homme Profil pro
    Développeur Java/Java EE/Android
    Inscrit en
    Mai 2012
    Messages
    163
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Java/Java EE/Android

    Informations forums :
    Inscription : Mai 2012
    Messages : 163
    Points : 134
    Points
    134
    Par défaut
    Merci fr1man. C'est parfait!
    Si vous avez de l'Amour, vous ne ferez du mal à personne et personne ne vous fera du mal. W M Branham

  8. #8
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    365
    Détails du profil
    Informations personnelles :
    Localisation : Maroc

    Informations forums :
    Inscription : Janvier 2006
    Messages : 365
    Points : 495
    Points
    495
    Par défaut
    Une autre façon de faire serait:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT p FROM Personne p WHERE p.activites IS EMPTY
    ce qui est équivalent à :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT p FROM Personne p WHERE SIZE(p.activites) = 0
    SCJP 5 / SCBCD 1.3 Certified

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Requête JPQL avec MINUS
    Par JacNar6 dans le forum JPA
    Réponses: 2
    Dernier message: 20/08/2013, 10h52
  2. Réponses: 1
    Dernier message: 14/04/2013, 04h04
  3. Erreur de syntaxe avec les requêtes JPQL
    Par diengkals dans le forum Java EE
    Réponses: 12
    Dernier message: 02/02/2011, 23h44
  4. Requête avec "MINUS" refusée
    Par pok4ever dans le forum Requêtes
    Réponses: 10
    Dernier message: 30/04/2010, 11h09
  5. Requête avec "MINUS" refusée
    Par brunoperel dans le forum Requêtes
    Réponses: 3
    Dernier message: 22/01/2008, 15h04

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo