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

 

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    novembre 2017
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : novembre 2017
    Messages : 35
    Points : 46
    Points
    46

    Par défaut Importer en filtrant une liste de valeur avec dbGetQuery

    Bonjour,

    Je souhaiterai filtrer des valeurs sur une table que j'importe dans R à l'aide de DbGetQuery.
    Malheureusement, je peux pas effectuer mon filtre après car la base est trop volumineuse pour être importée et pour que je puisse effectuer mon filtre sur certaine valeur ensuite.

    déroulement de mon code:
    Première étape: j'édite mon query avec une requête SQL

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    query = "Select * from ma_table where mes_valeur = 'valeur_1' OR ....   'valeur_N'"
    Deuxième étape: j'importe la table

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ma_base = dbgetquery(my_db, query)
    Seulement, j'aurai besoin de pouvoir mettre dans mon query une liste (qui est déjà présente dans mon interface), je ne peux pas la recopier à la main car elle est beaucoup trop longue.

    Je vous remercie d'avance pour vos réponses

  2. #2
    Modératrice

    Femme Profil pro
    Statisticienne, Fondatrice de la société DACTA
    Inscrit en
    juin 2010
    Messages
    865
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Statisticienne, Fondatrice de la société DACTA

    Informations forums :
    Inscription : juin 2010
    Messages : 865
    Points : 2 587
    Points
    2 587

    Par défaut

    Bonjour,

    Voir du côté de la fonction "paste".
    Par exemple, quelque chose sur ce modèle (à adapter) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ma_liste <- c("valeur_1", ..., "valeur_N")
     
    query = paste0("Select * from ma_table where mes_valeur = ",  paste(ma_liste, collapse = " OR "))
    HTH !


    Cordialement,


    A.D.

    Forum R
    Fournir le code utilisé (pensez aux balises code !), les packages nécessaires, ainsi qu'un court mais représentatif extrait du jeu de données et les éventuels messages d'erreur.
    Recherche d'informations concernant R : RSiteSearch / tutoriels : http://r.developpez.com/cours/ .

    Pensez également au bouton "Résolu" et à voter (en bas à droite des messages) lorsque vous avez obtenu une réponse satisfaisante.

  3. #3
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    novembre 2017
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : novembre 2017
    Messages : 35
    Points : 46
    Points
    46

    Par défaut

    Super, j'ai modifié un peu le code et ça fonctionne !

    Du coup le code utilisé c'est

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    ma_liste <- c("valeur_1", ..., "valeur_N")
     
    query_1 = paste0("Select * from ma_table where mes_valeur = ' ",  paste(ma_liste, collapse = " OR mes_valeur=' "))
    query_2 = " ' "
     
    query = paste(query_1, query_2, sep="")
    Merci beaucoup pour le paste ! problème résolu

  4. #4
    Modératrice

    Femme Profil pro
    Statisticienne, Fondatrice de la société DACTA
    Inscrit en
    juin 2010
    Messages
    865
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Statisticienne, Fondatrice de la société DACTA

    Informations forums :
    Inscription : juin 2010
    Messages : 865
    Points : 2 587
    Points
    2 587

    Par défaut

    Bonjour,

    Ravie d'avoir pu aider

    Deux petites infos complémentaires (et utiles je pense ^^) :

    • On peut concaténer plus de 2 éléments avec un seul appel à "paste" : paste("a", "b", "c") .
    • La commande : paste("a", "b", sep ="") est équivalente à : paste0("a", "b")


    Bonne continuation !


    Cordialement,


    A.D.

    Forum R
    Fournir le code utilisé (pensez aux balises code !), les packages nécessaires, ainsi qu'un court mais représentatif extrait du jeu de données et les éventuels messages d'erreur.
    Recherche d'informations concernant R : RSiteSearch / tutoriels : http://r.developpez.com/cours/ .

    Pensez également au bouton "Résolu" et à voter (en bas à droite des messages) lorsque vous avez obtenu une réponse satisfaisante.

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 11/01/2014, 12h16
  2. [2.x] Supprimer une liste de valeur avec un Query Builder
    Par pmithrandir dans le forum Symfony
    Réponses: 1
    Dernier message: 02/06/2013, 20h09
  3. import/export d'une liste avec stsadm
    Par Benzeghiba dans le forum SharePoint
    Réponses: 1
    Dernier message: 08/09/2008, 12h11
  4. Réponses: 4
    Dernier message: 25/08/2008, 14h54
  5. ORACLE : pseudo-table avec une liste de valeurs
    Par LEPTMR dans le forum Langage SQL
    Réponses: 2
    Dernier message: 10/11/2006, 17h02

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