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

PostgreSQL Discussion :

Créer un tableau avec modification à la volée [8.4]


Sujet :

PostgreSQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2012
    Messages
    77
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Septembre 2012
    Messages : 77
    Par défaut Créer un tableau avec modification à la volée
    Bonjour,

    Je suis en train de faire un select sur plusieurs tables de ma base afin de récupérer diverses données et faire un export csv.
    Dans mon gros select, je suis en train de buter sur un sous-select que je n'arrive pas à construire.

    Dans ce sous select, je dois récupérer une liste de données (chaines de caractères) concaténées.
    Or voilà, c'est données sont des booléens(NUMBER(1)) dans ma base (ces données correspondent à des check box dans l'application).

    Imaginons que j'ai ma table FRUIT comme ceci :
    CHAMP/VALEUR/Commentaire
    -----------------------------------------------
    FRUITPOMME | 1 | Pomme ?
    FRUITFRAISE | 1 | Fraise ?
    FRUITPOIRE | 0 | Poire?
    Dans mon export doit sortir 'Pomme,Fraise'.
    Pour créer la chaine concaténée, je pensais utiliser
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT array_to_string(array_append(array_cat(FRUITPOMME,FRUITFRAISE),FRUITPOIRE),',');
    Mais voilà, avec ça je vais récupérer '1,1,0' alors que je veux 'Pomme,Fraise' (Poire n'apparaît pas car 0).

    Comme je suis déjà dans un select, je ne pense pas pouvoir effectuer morceau par morceau les différentes conversions puis tout concaténer, donc je suis à la recherche d'une fonction qui me permettrait de tout faire d'un bloc, si ça existe. Sinon, des idées, ça me va aussi!

    Merci!

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Essayez ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    select array_to_string(array_agg(commentaire), ',') as result
      from (values ('FRUITPOMME' , true , 'Pomme' )
                 , ('FRUITFRAISE', true , 'Fraise')
                 , ('FRUITPOIRE' , false, 'Poire' )) as sr (champ, valeur, commentaire)
     where valeur;
     
    RESULT
    ------------
    Pomme,Fraise

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

Discussions similaires

  1. Créer un tableau avec Zend
    Par salmoucha dans le forum MVC
    Réponses: 12
    Dernier message: 16/12/2009, 03h51
  2. Créer un tableau avec "retrait à gauche"
    Par HomoErectus dans le forum VBA Word
    Réponses: 5
    Dernier message: 09/02/2009, 15h52
  3. Créer un tableau avec les graphes
    Par romero2008 dans le forum Pascal
    Réponses: 6
    Dernier message: 25/04/2008, 22h30
  4. Créer un tableau avec access comme sur les pages web
    Par celiaaa dans le forum VBA Access
    Réponses: 3
    Dernier message: 02/06/2007, 22h53
  5. Réponses: 2
    Dernier message: 15/12/2006, 14h22

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