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 Firebird Discussion :

Requete avec resultat en matrice


Sujet :

SQL Firebird

  1. #1
    Membre du Club
    Inscrit en
    Juillet 2008
    Messages
    79
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 79
    Points : 58
    Points
    58
    Par défaut Requete avec resultat en matrice
    Bonjour;
    Je cherche une méthode pour aficher les résultat de la requete suivante en colone:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT EMPL.CODE, EMPL.NOM , EMPL.PRENOM, EMPL.CODEMAT, MAT.LIBMAT
    FROM EMPL, MAT
    WHERE
    EMPL.CODEMAT = MAT.CODEMAT
    je voudrais ce résultat :

    CODE NOM PRENOM CODEMAT1 LIBMAT1 CODEMAT2 LIBMAT2 ....... ........ ....... ...........

  2. #2
    Membre confirmé Avatar de JustMe
    Inscrit en
    Juillet 2002
    Messages
    479
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 479
    Points : 593
    Points
    593
    Par défaut
    Je crains que ça ne soit possible.
    <On fait la science avec des faits, comme on fait une maison avec des pierres : mais une accumulation de faits n'est pas plus une science qu'un tas de pierres n'est une maison> **Poincaré**

  3. #3
    dug
    dug est déconnecté
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    151
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 151
    Points : 84
    Points
    84
    Par défaut
    j'ai pas compris ce que tu cherches à faire...

    tu la vois ou ta matrice ? ( tu es pas demain par hasard ? )

    ça ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT EMPL.CODE, EMPL.NOM , EMPL.PRENOM, EMPL.CODEMAT, MAT.LIBMAT
    FROM EMPL, MAT
    WHERE EMPL.CODEMAT = MAT.CODEMAT
    GROUP BY EMPL.CODE, EMPL.NOM , EMPL.PRENOM
    ps: en tout cas, c'est bizarre que cela soit pas possible... peut etre simplement alors...
    tu peux faire des requêtes imbriqués, avec CASE pour savoir si tu changes de groupe. tu as aussi la fonction liste pour regrouper les autres champs en une colonnes...

  4. #4
    Membre confirmé Avatar de JustMe
    Inscrit en
    Juillet 2002
    Messages
    479
    Détails du profil
    Informations forums :
    Inscription : Juillet 2002
    Messages : 479
    Points : 593
    Points
    593
    Par défaut
    Non je pense qu'il veux que tous ses résultats apparaissent en colonnes.
    <On fait la science avec des faits, comme on fait une maison avec des pierres : mais une accumulation de faits n'est pas plus une science qu'un tas de pierres n'est une maison> **Poincaré**

  5. #5
    Membre du Club
    Inscrit en
    Juillet 2008
    Messages
    79
    Détails du profil
    Informations forums :
    Inscription : Juillet 2008
    Messages : 79
    Points : 58
    Points
    58
    Par défaut
    oui c'est ça je veut les résultats en colonne

  6. #6
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 042
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 042
    Points : 40 952
    Points
    40 952
    Billets dans le blog
    62
    Par défaut
    Après quelques tests d'utilisation des CTEs voir iciet de LIST et là, il me semble que la demande est réalisable avec Firebird 2.1 (quoique je n'en vois pas bien le propos)

    cela donnerait quelque chose de ce style

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    WITH UNECTE (CODE,NOM,PRENOM,MATETLIB) 
        AS (SELECT E.CODE,E.NOM,E.PRENOM,E.CODEMAT||' '||M.LIBMAT
              FROM EMPL E JOIN MAT M
              ON M.CODEMAT=E.CODEMAT)
    SELECT CODE,NOM,PRENOM,LIST(MATETLIB,':') FROM UNECTE
    GROUP BY CODE,NOM,PRENOM
    devrait donner ceci
    CODE NOM PRENOM CODEMAT1:LIBMAT1 CODEMAT2:LIBMAT2 ......:........
    Quoique à retardement je me demande si :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT E.CODE,E.NOM,E.PRENOM,LIST(E.CODEMAT||' '||M.LIBMAT,' : ')
              FROM EMPL E JOIN MAT M
              ON M.CODEMAT=E.CODEMAT
    GROUP BY E.CODE,E.NOM,E.PRENOM
    ne ferait pas la même chose , mais c'est trop tard , je viens d'effacer le petit jeu d'essai servant au test de la proposition n°1
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

Discussions similaires

  1. requetes avec resultats errones
    Par sissialias dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 14/03/2009, 13h39
  2. Requete avec resultat en matrice
    Par tarek_ep dans le forum Bases de données
    Réponses: 3
    Dernier message: 21/02/2009, 15h02
  3. [Oracle / Sql] clause where avec resultat d'une requete
    Par shaun_the_sheep dans le forum Oracle
    Réponses: 2
    Dernier message: 31/01/2006, 09h37
  4. [MySQL] Comparer le resultat d'une requete avec des fichiers
    Par Anakior dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 20/12/2005, 11h11
  5. probleme de requete avec reprise du resultat :
    Par Maxoo dans le forum Langage SQL
    Réponses: 6
    Dernier message: 13/12/2004, 20h05

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