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 :

Ajouter des lignes "manquantes"


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Avatar de Seb33300
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2007
    Messages
    1 564
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : Thaïlande

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 564
    Par défaut Ajouter des lignes "manquantes"
    Bonjour,

    J'ai une requête qui me permet d'obtenir une table qui contient des données de cette forme :

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Jour|Qte
    ----|----
      1 | 15
      2 |  20
      3 | 42
    etc...

    Cependant, je n'ai pas de données pour certains jours (week end, jours fériés, etc... par exemple).
    Je me retrouve donc avec un résultat de la forme :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Jour|Qte
    ----|----
      1 | 15
      2 |  20
      3 | 42
      6 | 50
      7 | 53
    etc...

    Existe t il un moyen simple de déterminer les "Jours" manquant et de les rajouter dans le résultat en reprenant la "Qte" du jour précédent, de cette manière :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Jour|Qte
    ----|----
      1 | 15
      2 |  20
      3 | 42
      4 | 42
      5 | 42
      6 | 50
      7 | 53
    etc...

    Jeu de données :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    CREATE TABLE TABLE_TEST (Jour INT, Qte INT)
    INSERT INTO TABLE_TEST VALUES (1, 15)
    INSERT INTO TABLE_TEST VALUES (2, 20)
    INSERT INTO TABLE_TEST VALUES (3, 42)
    INSERT INTO TABLE_TEST VALUES (6, 50)
    INSERT INTO TABLE_TEST VALUES (7, 53)
    Merci

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 999
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 999
    Billets dans le blog
    6
    Par défaut
    Par principe : une base de données ne sait pas inventer des données qu'elle n'a pas !
    Vous devez donc ajouter dans votre base une table de toutes les dates.
    Ceci devrait être obligatoire dans tous les MCD dès qu'il existe une colonne DATE.
    Inspirez vous de l'article que j'ai écrit à ce sujet : http://sqlpro.developpez.com/cours/gestiontemps/

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre Expert
    Avatar de Seb33300
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2007
    Messages
    1 564
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : Thaïlande

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 564
    Par défaut
    Je viens de trouver une solution qui me convient même si elle ne comble pas tous les trou, elle comble le trou précédent chaque valeur

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT Jour, Qte FROM TABLE_TEST
    UNION
    SELECT Jour-1, (SELECT SUM(Qte) FROM TABLE_TEST WHERE Jour<t.Jour) FROM TABLE_TEST as t
    WHERE (Jour-1)>0
     
    ORDER BY Jour, Qte

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 999
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 999
    Billets dans le blog
    6
    Par défaut
    Bonjour les performances quant vous aurez des milliers de lignes dans votre table !

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  5. #5
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    L'intérêt en plus d'avoir une table référence permet de calculer la somme cumulée de manière bien moins coûteuse :
    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
    29
    30
    31
    32
    DECLARE @TABLE_TEST TABLE (JOUR INT, QTE INT);
    INSERT INTO @TABLE_TEST VALUES (1, 15);
    INSERT INTO @TABLE_TEST VALUES (2,  5);
    INSERT INTO @TABLE_TEST VALUES (3, 22);
    INSERT INTO @TABLE_TEST VALUES (6,  8);
    INSERT INTO @TABLE_TEST VALUES (7,  3);
     
    WITH NUMEROS (JOUR) AS
    (
    SELECT 1
    UNION ALL
    SELECT JOUR + 1
    FROM NUMEROS
    WHERE JOUR < 7
    )
      SELECT N.JOUR,
             SUM(T.QTE) AS QTE_CUMUL
        FROM NUMEROS AS N
             LEFT OUTER JOIN @TABLE_TEST AS T
               ON T.JOUR <= N.JOUR
    GROUP BY N.JOUR
    ORDER BY N.JOUR ASC;
     
    JOUR        QTE_CUMUL
    ----------- -----------
    1           15
    2           20
    3           42
    4           42
    5           42
    6           50
    7           53

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 11
    Dernier message: 10/11/2010, 08h33
  2. Réponses: 14
    Dernier message: 22/09/2005, 16h49
  3. [Fichier] Ajout des lignes de doc dans arraylist
    Par 3adoula dans le forum Entrée/Sortie
    Réponses: 9
    Dernier message: 29/04/2004, 22h41

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