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

SQL Oracle Discussion :

Regroupement d'informations dans un seul tuple


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    29
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 29
    Par défaut Regroupement d'informations dans un seul tuple
    Bonjour,

    je cherche une solution pour mon problème sur un select.

    Je possède une table utilisateur et une table de numéro de téléphone associé a ces utilisateurs.

    Mon problème est que je voudrais obtenir une seule ligne par personne mais avec les numéros de téléphone dans une seule colonne

    Exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    NOM   PRENOM  Telephone
     
                          Fixe : 000000000
    TOTO Alfred      Portable : 111111111
                          Professionnel : 222222222
    Est ce que ce traitement est possible par un simple select ou bien un traitement par bloc PL/SQL est forcement necessaire

    Merci à tous

  2. #2
    Membre Expert Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 38
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Par défaut
    Il ne me semble pas que c'est possible, tu peux par contre présenter sous les formes :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    NOM   PRENOM  Telephone                         
    TOTO Alfred Fixe : 000000000 
    TOTO Alfred Portable : 111111111                       
    TOTO Alfred Professionnel : 222222222
    Ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    NOM   PRENOM Fixe Portable Professionnel 
    TOTO Alfred 000000000 111111111 222222222
    Sachant que normalement que tout ce qui est affaire de mise en forme relève de l'application.

  3. #3
    Membre chevronné
    Avatar de Bibeleuh
    Homme Profil pro
    Développeur
    Inscrit en
    Septembre 2010
    Messages
    209
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2010
    Messages : 209
    Par défaut
    Salut,

    Il existe une fonction spécifique Oracle 11G permettant d’afficher plusieurs lignes en une seule : LISTTAG

    Exemple :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    select  nom , LISTAGG(telephone,' - ') within group (order by nom) telephones
    from 
    (
        select 'TOTO Alfred' as nom , 'Fixe : 000000000' as telephone from dual
        union
        select 'TITI Alfred' as nom, 'Domicile : 0000048900'  as telephone from dual
        union
        select 'TITI Alfred' as nom , 'Fixe  : 000044560' as telephone from dual
        union
        select 'TOTO Alfred' as nom , 'Portable : 000000000' as telephone from dual
     
    )
    group by nom ;

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    NOM              TELEPHONES
    TITI Alfred      Domicile : 0000048900 - Fixe  : 000044560
    TOTO Alfred      Fixe : 000000000 - Portable : 000000000
    Cela peut t'aider si tu travailles sous Oracle 11

  4. #4
    Membre Expert Avatar de ojo77
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Décembre 2010
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Rhône (Rhône Alpes)

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

    Informations forums :
    Inscription : Décembre 2010
    Messages : 680

Discussions similaires

  1. [CR10] Regrouper deux rapports dans un seul
    Par reda-ziad dans le forum SAP Crystal Reports
    Réponses: 1
    Dernier message: 17/01/2007, 15h44
  2. regrouper 2 .PDF dans un seul !
    Par SuperOliV dans le forum Autres Logiciels
    Réponses: 1
    Dernier message: 27/09/2006, 13h14
  3. regrouper des informations dans une seule ligne
    Par rozow dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 11/04/2006, 16h03
  4. regrouper plusieurs champ dans un seul en requete
    Par Nicko29 dans le forum Access
    Réponses: 12
    Dernier message: 07/09/2005, 18h29
  5. Regrouper 3 requêtes dans une seule
    Par LadyArwen dans le forum Langage SQL
    Réponses: 4
    Dernier message: 21/06/2003, 09h32

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