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

MS SQL Server Discussion :

transformation des lignes en colonne


Sujet :

MS SQL Server

Vue hybride

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

    Informations forums :
    Inscription : Avril 2009
    Messages : 70
    Par défaut transformation des lignes en colonne
    Bonjour a tous,

    Aprés plusieurs recherche sur le net je n'arrive pas à retrouver une solution à mon problème.
    Alors en fait je dois extraire des données de la base de prod. Donc j'ai le droit de faire que des select sur sql serveur. A la fin je dois reproduire une requête qui permettera d'extraire les données sous une forme bien précise.

    j'ai une table testbase sous la forme suivante:

    ID DATE_P PERIODE TYPE Montant
    1 12/03/2012 2 EN 3000
    1 12/04/2012 5 ES 400
    1 12/04/2012 5 EN 500
    2 12/03/2012 4 EM 900
    3 12/04/2012 5 ES 400


    je souhaite avoir comme résultat, aprés une condition sur les dates et un max sur la periode :


    ID DATE_P PERIODE EN EM ES
    1 12/04/2012 5 500 400
    3 12/04/2012 5 400

    En d'autre terme transformer les lignes type en colonne.
    j'ai essayé avec la fonction PIVOT cela ne marchait pas. sachant que j'ai 200 type alors je souhaite avoir les 200 colonne.


    Merci d'avance
    Cordialement

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    c'est pourtant bien PIVOT qu'il faut utiliser. (Encore qu'il serait plus judicieux de ramener les résultats sur plusieurs lignes, et de pivoter dans votre application au moment de l'affichage, surtout pour 200 colonnes : votre serveur de BDD vous en sera éternellement reconnaissant ! )

    pourriez-vous être plus précis que
    cela ne marchait pas

  3. #3
    Membre éprouvé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    93
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 93
    Par défaut
    Salut,

    Qu'est-ce qui ne marche pas ? Car avec un pivot c'est réalisable.

    Si tu ne veux pas te palucher les 200 types différents, il faut que tu génères ta requête dynamiquement.

    Sinon ramène tes données dans l'application et c'est dans le code que tu feras ta mise en forme (ce qui est logique).

    EDIT : grillé

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    70
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2009
    Messages : 70
    Par défaut
    voila le code que j'utilise, je n'arrive pas à le faire tourner
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
     
    DECLARE @cols NVARCHAR(2000)
    DECLARE @query NVARCHAR(4000)
     
    SELECT @cols = STUFF(( SELECT DISTINCT TOP 100 PERCENT
                                    '],[' + t.TYPE
                            FROM    testbase t
                            ORDER BY '],[' + t.TYPE
                            FOR XML PATH('')
                          ), 1, 2, '') + ']'
     
    SET @query = N'SELECT '+ @cols +' FROM
    (SELECT t.TYPE, t.montant FROM testbase t) p
    PIVOT (MAX([Count]) FOR t.TYPE IN ( '+ @cols +' ))
    AS pvt;'
     
    EXECUTE(@query)
    d’après ce que j' avais compris vu que le libellé du type dépasse les 128 caractère alors la requête block

  5. #5
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    C'est en effet le cas, et de façon générale, un nom de colonne ne peut pas excéder 128 caractères.

    Enfin mon avis, c'est qu'avec 200 colonnes ayant des noms de plus de 128 caractère, il faudra au moins un écran de 32000 pouces pour afficher tout ça

    plus sérieusement, pourquoi n'effectuez pas l'opération de pivot dans votre applicatif ?

    alternativement, vous pouvez faire un pivot "à l'ancienne" en renommant les colonnes (avec un peu de chance, le moteur mettra moins de temps à l’exécuter que vous n'en aurez mis à l'écrire...)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT 
        id
        ,MAX (CASE WHEN Colonne1 = 'XX' THEN Colonne2 END) AS XX,
        ,MAX (CASE WHEN Colonne1 = 'YYet128Caractères' THEN Colonne2 END) AS YY
        ,...
    FROM LaTable
    GROUP BY id

Discussions similaires

  1. Requête SQL, transformer des lignes en colonne
    Par gadget2 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 01/11/2010, 21h50
  2. [Datastage Server 7.5] Transformer des lignes en colonnes
    Par alpachico dans le forum DataStage
    Réponses: 1
    Dernier message: 10/07/2009, 17h25
  3. Transformer des lignes en colonnes
    Par Gomoz dans le forum Requêtes
    Réponses: 1
    Dernier message: 17/02/2009, 18h55
  4. Transformer des lignes en colonne DataStage
    Par bnet2 dans le forum DataStage
    Réponses: 4
    Dernier message: 09/12/2008, 11h07
  5. Transformer des lignes en colonnes
    Par ofinot dans le forum Requêtes et SQL.
    Réponses: 15
    Dernier message: 30/07/2008, 12h45

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