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 :

Requête complexe dans MOngoDB


Sujet :

NoSQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mai 2012
    Messages
    175
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2012
    Messages : 175
    Par défaut Requête complexe dans MOngoDB
    Bonjour à tous,

    C'est la première fois que j'utilise une base Nosql MongoDB et je trouve encore des difficultés à interroger la base avec des requêtes un peu complexe.

    J'ai essayé par exemple de déterminer le nombre des éléments uniques d'un tel variable (count(distinct("colonne")) dans Mysql) mais toujours en vain !

    Avez-vous une idée comment je peux avoir cette information dans MongoDB s'il vous plaît ?

    Toute information sera le bien venue et Merci d'avance !

  2. #2
    Membre chevronné Avatar de Sebwar
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2012
    Messages
    172
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2012
    Messages : 172
    Par défaut
    Hello !

    Voila un petit exemple

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select count(distinct champ) from collection where status = 10
    =
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    db.collection.distinct("champ", {status : 10}).length

  3. #3
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Mai 2012
    Messages
    175
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2012
    Messages : 175
    Par défaut
    Je vous remercie pour votre réponse.

    j'ai une collection contenant à peu près 20 millions de documents. Chaque document correspond aux posts (commentaires) dans une plateforme d'information. Chaque document contient ces éléments (id, URL, author, content, likes, dislikes).

    J'ai essayé d'extraire par exemple le nombre des posts par auteur et ça m'a pris énormément de temps sans avoir que les résultats pour 180 auteurs alors qu'on a plus de 500 000 auteurs. A ce rythme, il me faut des mois pour avoir ces stats !!

    Je suis encore novice en MongoDb. Pourriez-vous me recommander quelques techniques afin d’accélérer les requêtes s'il vous plait et ainsi bien exploiter ma collection ?

    Même quand j'exécute la requête permettant d'identifier le nombre des URL distincts, ça me prend des heures pour avoir une réponse...

  4. #4
    Membre chevronné Avatar de Sebwar
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2012
    Messages
    172
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2012
    Messages : 172
    Par défaut
    Il est important de mettre des indexes pour accélérer les requêtes.

    sur votre champ "author" par exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    db.ta_collection.ensureIndex( {"author": 1})
    pour compter le nombre de post par auteur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    db.ta_collection.aggregate(
      [
        {
          $group : {
            _id : {
              auteur: "$author",
            },
            count: { $sum: 1 }
          }
        }
       ]
    )

  5. #5
    Membre très actif
    Avatar de landry161
    Homme Profil pro
    C#,PHP,MySQL,Android...
    Inscrit en
    Juillet 2010
    Messages
    423
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : C#,PHP,MySQL,Android...

    Informations forums :
    Inscription : Juillet 2010
    Messages : 423
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Sebwar Voir le message
    Il est important de mettre des indexes pour accélérer les requêtes.
    Très important.

Discussions similaires

  1. [MySQL] syntaxe error dans une requête complexe
    Par info_sara dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 28/06/2008, 20h56
  2. [AXIS2] Envoi d'un type complexe dans une requête SOAP
    Par godolf dans le forum Services Web
    Réponses: 4
    Dernier message: 20/05/2008, 13h51
  3. Problème de doublons dans une requète complexe
    Par noakiss dans le forum Langage SQL
    Réponses: 7
    Dernier message: 20/03/2008, 09h19
  4. Doublons dans une requète complexe
    Par noakiss dans le forum VBA Access
    Réponses: 0
    Dernier message: 19/03/2008, 15h30
  5. Calculs complexes dans une requête
    Par ARRG dans le forum Langage SQL
    Réponses: 5
    Dernier message: 06/06/2005, 19h11

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