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

Développement SQL Server Discussion :

SQL 2005 Requete PIVOT


Sujet :

Développement SQL Server

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Novembre 2003
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 1
    Points : 1
    Points
    1
    Par défaut SQL 2005 Requete PIVOT
    Bonjour,
    J'ai la table suivante :
    Site | Name | Value | Month
    SiteA | NameA | 83 | 7
    SiteA | NameB | 95 | 7
    SiteB | NameA | 75 | 7
    SiteB | NameB | 60 | 7
    SiteA | NameA | 56 | 8
    SiteA | NameB | 40 | 8
    SiteB | NameA | 78 | 8
    SiteB | NameB | 67 | 8
    etc...

    j'essaie de faire une requete PIVOT pour avoir le resultat suivant :
    Site | NameA | NameB
    SiteA | 139 | 135
    SiteB | 153 | 127
    etc...

    Ma requete est la suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT Site, [NameA] as NameA, [NameB] as NameB
    FROM  (SELECT * FROM mytable WHERE (Month=7 OR Month=8) AND (Name='NameA' OR Name='NameB')) AS source 
    PIVOT (SUM(Value) FOR Name IN ([NameA], [NameB])) AS mois
    GROUP BY Site, [NameA], [NameB]
    Voici le resultat que ça me donne:
    Site | NameA |NameB
    SiteA | NULL | 95
    SiteA | NULL | 40
    SiteA | 83 | NULL
    SiteA | 56 | NULL
    SiteB | NULL | 60
    SiteB | NULL | 67
    etc...

    qu'est-ce qui cloche dans ma requete ?

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 52
    Points : 62
    Points
    62
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    select site 
             , sum([NameA ])
             , sum([NameB ])
    from mytable 
    pivot
    (
       sum(value) for name in ([NameA ], [NameB ])
    ) Resultat
    group by site
    @+

Discussions similaires

  1. [SQL 2005] Requetes ne se termine jamais
    Par lanjolanjo dans le forum Administration
    Réponses: 2
    Dernier message: 16/06/2009, 21h46
  2. SQL 2005 ET PIVOT
    Par tiferg dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 28/11/2008, 12h43
  3. [debutant]SQL 2005 + requete select ?
    Par christopheEU dans le forum Développement
    Réponses: 1
    Dernier message: 04/04/2008, 14h26
  4. [debutant]SQL 2005 + requete select ?
    Par christopheEU dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 04/04/2008, 14h26
  5. Requete ne passe pas sous Sql 2005
    Par dd16 dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 02/06/2006, 13h03

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