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 :

SQL consolider des valeurs dans deux champs


Sujet :

MS SQL Server

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 8
    Points : 3
    Points
    3
    Par défaut SQL consolider des valeurs dans deux champs
    Bonjour,

    J’aurais aimé faire un truc dans SQL… mais j’arrive pas.

    Explications :
    J’ai un client TOTO qui est scindé en 3 entités « TOTO_1», « TOTO_2 » et « TATA »

    J’ai la requête suivante
    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
    SELECT
          COUNT(DISTINCT RFC_NUMBER) AS nbTickets
          ,DEPARTMENT_FR
          ,MONTH(SUBMIT_DATE_UT) AS mois
          ,YEAR(SUBMIT_DATE_UT) AS annee
     
    FROM
          [50005].SD_REQUEST
          ,[50005].AM_DEPARTMENT
     
    WHERE
          SD_REQUEST.DEPARTMENT_ID = AM_DEPARTMENT.DEPARTMENT_ID
          AND YEAR(SUBMIT_DATE_UT)='2013'
          AND (DEPARTMENT_FR LIKE 'TOTO%' OR DEPARTMENT_FR LIKE 'TATA')
     
    GROUP BY DEPARTMENT_FR,YEAR(SUBMIT_DATE_UT),MONTH(SUBMIT_DATE_UT)
    ORDER BY DEPARTMENT_FR,YEAR(SUBMIT_DATE_UT),MONTH(SUBMIT_DATE_UT)
    Le résultat fait apparaitre les 3 entités TOTO_1, TOTO_2 et TATA.

    Or, je souhaite additionner le nombre de tickets « nbTickets » de TOTO_1, TOTO_2 sous une seule entité « TOTO » et laisser « TATA » à part. Et ça, j’arrive pas à le faire….

    Si vous avez une idée, je suis preneur !

  2. #2
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2008
    Messages
    699
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Boutique - Magasin

    Informations forums :
    Inscription : Octobre 2008
    Messages : 699
    Points : 586
    Points
    586
    Par défaut
    ça manque un peu d'information sur les tables,

    Avez-vous une clé ou une entité qui permette de faire la relation entre les 3 clients ?

  3. #3
    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
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Sur le principe vous pouvez faire comme ceci :

    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
     
    SELECT
          COUNT(DISTINCT RFC_NUMBER) AS nbTickets
          ,CASE 
              WHEN DEPARTMENT_FR LIKE 'TOTO%' THEN 'TOTO'
              ELSE DEPARTMENT_FR 
           END AS Departement
     
          ,MONTH(SUBMIT_DATE_UT) AS mois
          ,YEAR(SUBMIT_DATE_UT) AS annee
     
    FROM
          [50005].SD_REQUEST
          ,[50005].AM_DEPARTMENT
     
    WHERE
          SD_REQUEST.DEPARTMENT_ID = AM_DEPARTMENT.DEPARTMENT_ID
          AND YEAR(SUBMIT_DATE_UT)='2013'
          AND (DEPARTMENT_FR LIKE 'TOTO%' OR DEPARTMENT_FR LIKE 'TATA')
     
    GROUP BY 
           CASE 
              WHEN DEPARTMENT_FR LIKE 'TOTO%' THEN 'TOTO'
              ELSE DEPARTMENT_FR 
           END,
           YEAR(SUBMIT_DATE_UT),
           MONTH(SUBMIT_DATE_UT)
    ORDER BY Departement,YEAR(SUBMIT_DATE_UT),MONTH(SUBMIT_DATE_UT)
    Mais comme le suggère Donpi, si vous avez les données de regroupement renseignées dans une table, vous pourriez faire une jointure, ce qui serait plus simple

    Par ailleurs, votre filtre sur la date empêchera l'utilisation d'un éventuel index.
    Pour filtrer sur l'année 2013, vous devriez l'écrire ainsi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    WHERE SUBMIT_DATE_UT >= '20130101' AND SUBMIT_DATE_UT < '20140101'
    et pour filtrer dynamiquement sur l'année en cours :
    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
    18
    19
     
    WHERE SUBMIT_DATE_UT >= DATEADD(
    			YEAR,
    			DATEDIFF(
    				YEAR,
    				0,
    				GETDATE()
    			)
    		,0
    		)
        AND SUBMIT_DATE_UT < DATEADD(
    			YEAR,
    			DATEDIFF(
    				YEAR,
    				0,
    				GETDATE()
    			) + 1
    		,0
    		)

  4. #4
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2008
    Messages
    699
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Boutique - Magasin

    Informations forums :
    Inscription : Octobre 2008
    Messages : 699
    Points : 586
    Points
    586
    Par défaut
    Hmmm j'avais pas percuté que par client vous vouliez dire departement

Discussions similaires

  1. Impossible d'insérer des valeurs dans un champ
    Par Sixpounder dans le forum Paradox
    Réponses: 1
    Dernier message: 08/07/2011, 16h00
  2. Recherche une valeur dans deux champs
    Par smotte761 dans le forum Langage
    Réponses: 2
    Dernier message: 25/03/2011, 17h13
  3. [AC-2003] Référencer des valeurs dans un champs de calcul
    Par Piccou dans le forum Requêtes et SQL.
    Réponses: 10
    Dernier message: 24/08/2009, 15h47
  4. Réponses: 4
    Dernier message: 23/04/2008, 17h03
  5. [MS SQL] Remplacer des valeurs dans plusieurs tables
    Par salmoliv dans le forum Langage SQL
    Réponses: 3
    Dernier message: 04/10/2006, 17h31

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