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

NoSQL Discussion :

jointure entre document avec element qui n'est pas cle unique


Sujet :

NoSQL

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 42
    Points : 34
    Points
    34
    Par défaut jointure entre document avec element qui n'est pas cle unique
    Bonjour,
    J'avais deux documents:
    une classe entreprise
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    @Document(collection = "Entreprise")
    public class Entreprise  implements Serializable {
     
    	/**
    	 * 
    	 */
    	private static final long serialVersionUID = 7702602531205811976L;
     
    	@Id
    	private String id;
     
     
    	private String nomEntreprise;
     
     
    }
    et une classe Employe:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    @Document(collection = "Employe")
    public class Employe  implements Serializable {
     
    	/**
    	 * 
    	 */
    	private static final long serialVersionUID = 7702602531205811976L;
     
    	@Id
    	private String id;
     
    	@DBRef
    	private Entreprise entreprise;
     
     
    }
    je veux récupérer tous les employés qui ont le nom d'entreprise par exemple = "TOTO";

    J'utilise mongoDB
    voila ma requête que je fais :

    db.employe.find({'entreprise' : { '$ref' : "entreprise" , "$nomEntreprise" : "TOTO" } } ), cela ne marche pas je ne sais pas pourquoi.

    Pourtant quand j'utilise l'identifiant entreprise cela marche. Y-a-t-il une raison pour cela??

    db.employe.find({'entreprise.$id' : ObjectId("54250fd42d5d8c8e7677797a") } ) : cette requête fonctionne très

    Merci d'avance pour votre retour
    Cordialement

  2. #2
    Rédacteur

    Homme Profil pro
    Geek entrepreneur
    Inscrit en
    Novembre 2004
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Geek entrepreneur

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 224
    Points : 2 373
    Points
    2 373
    Par défaut
    vous utilisez des DBRef, cela ne sert pas à faire des "jointures" comme vous semblez l'entendre.
    Vous avez simplement stocké l'id de l'entreprise avec votre employé et votre driver execute une requete supplémentaire pour aller chercher l'entreprise a chaque fois que vous chargez l'employé.
    Mais en aucun cas il n'est capable de faire une requête de sélection en se basant sur une propriété de l'entreprise car il ne la connait qu'une fois qu'il a fait cette requête supplémentaire.
    En mongodb il n'existe pas de possibilité de faire une jointure.

    Bonne journée

Discussions similaires

  1. elements qui n'est pas dans une liste
    Par KEnder dans le forum Général Python
    Réponses: 2
    Dernier message: 16/05/2008, 01h52
  2. [RegEx] Isoler ce qui n'est pas entre guillemets
    Par novamax dans le forum Langage
    Réponses: 1
    Dernier message: 22/11/2007, 18h03
  3. Problème avec un div qui n'est pas pris en compte
    Par boss_gama dans le forum Général JavaScript
    Réponses: 11
    Dernier message: 25/07/2006, 16h32
  4. LIKE de tout ce qui n'est pas compris entre a<-&
    Par DjinnS dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 28/07/2003, 13h09

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