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 :

Requête avec CTE


Sujet :

Développement SQL Server

  1. #1
    Membre régulier
    Homme Profil pro
    ETUDE
    Inscrit en
    Septembre 2016
    Messages
    360
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : ETUDE
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Septembre 2016
    Messages : 360
    Points : 117
    Points
    117
    Par défaut Requête avec CTE
    Bonsoir à tous
    j'ai cette requête
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    WITH SOLDE 
    (MOIS, ANNEE, [Date_Operation],[IDCLIENT],[IDPRODUIT],[NumeroBon],[ENTTREE],[INDEX_OUVERTURE],[INDEX_FERMETURE],[SORTIE]
    ,[RC],[REPORT],[JAUGE],ECART,ETAT_STOCK) AS (SELECT DATENAME(MONTH,[Date_Operation]) AS MOIS,DATENAME(YEAR,[Date_Operation]) AS ANNEE, [Date_Operation],[IDCLIENT],[IDPRODUIT],[NumeroBon],[ENTTREE],[INDEX_OUVERTURE],[INDEX_FERMETURE],[SORTIE]
    ,[RC],[REPORT],[JAUGE]
    , (CASE WHEN COALESCE([JAUGE],0)>0 THEN (COALESCE([JAUGE],0))-(SUM((COALESCE([ENTTREE],0)+COALESCE([REPORT],0)-COALESCE([SORTIE],0)+COALESCE([RC],0)-COALESCE(PERTES,0))) OVER (PARTITION BY IDCLIENT,[IDPRODUIT]  ORDER BY [Date_Operation],[ENTTREE],[SORTIE])) END)  AS ECART
    , SUM((COALESCE([ENTTREE],0)+COALESCE([REPORT],0)-COALESCE([SORTIE],0)+COALESCE([RC],0)))   OVER (PARTITION BY IDCLIENT,[IDPRODUIT]  ORDER BY [Date_Operation],[ENTTREE],[SORTIE]) AS ETAT_STOCK
    from [dbo].[VGESTIONSORTIESTATIONS] )
    SELECT MOIS, ANNEE, [Date_Operation],[IDCLIENT],[IDPRODUIT],[NumeroBon],[ENTTREE],[INDEX_OUVERTURE],[INDEX_FERMETURE],[SORTIE]
    ,[RC],[REPORT],[JAUGE],ECART
    , SUM((COALESCE([ENTTREE],0)+COALESCE([REPORT],0)-COALESCE([SORTIE],0)+COALESCE([RC],0))+COALESCE([ECART],0))   OVER (PARTITION BY IDCLIENT,[IDPRODUIT]  ORDER BY [Date_Operation],[ENTTREE],[SORTIE]) AS ETAT_STOCK
    FROM SOLDE 
    WHERE   [Date_Operation]!='' AND ([ENTTREE]!='' OR [REPORT]!='' OR [SORTIE]!='' OR [RC]!='' OR [ECART]!='')AND IDCLIENT='CL17' AND [IDPRODUIT]='SUP01'
    je souhaite déterminer l'état de stocks en fonction de la colonne 'écart' et de la colonne 'jauge'
    Nom : Etatsstocks.PNG
Affichages : 127
Taille : 31,6 Ko
    mais comme vous pouvez constater à partir de la ligne 6 le résultat de la colonne 'ETAT_STOCK' n'est plus juste car la valeur de la colonne 'ECART' devrais être égal à 32.511 et je ne comprend pas pourquoi sa ne marche? quelqu'un pourrai m'aider à résoudre se problème? 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 763
    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 763
    Points : 52 554
    Points
    52 554
    Billets dans le blog
    5
    Par défaut
    Votre requête est strictement illisible. Commencez par enlever les crochets inutile et indentez correctement; Il y a des outils online sur le web pour cela.

    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 régulier
    Homme Profil pro
    ETUDE
    Inscrit en
    Septembre 2016
    Messages
    360
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : ETUDE
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Septembre 2016
    Messages : 360
    Points : 117
    Points
    117
    Par défaut
    Bonsoir SQLpro et merci pour votre réponse
    j’espère que la requête est plus lisible cette fois
    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
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    WITH SOLDE 
    (Date_Operation,
    IDCLIENT
    ,IDPRODUIT
    ,NumeroBon
    ,ENTTREE
    ,INDEX_OUVERTURE
    ,INDEX_FERMETURE
    ,SORTIE
    ,RC
    ,REPORT
    ,JAUGE
    ,ECART
    ,ETAT_STOCK)
     
     AS (SELECT 
     [Date_Operation]
     ,[IDCLIENT]
     ,[IDPRODUIT]
     ,[NumeroBon]
     ,[ENTTREE]
     ,[INDEX_OUVERTURE]
     ,[INDEX_FERMETURE]
     ,[SORTIE]
    ,RC,REPORT,JAUGE
    ------ calcul de l'ecart --------------------
    ,CASE WHEN COALESCE(JAUGE,0)>0 THEN (COALESCE(JAUGE,0))-(SUM((COALESCE(ENTTREE,0)+COALESCE(REPORT,0)-COALESCE(SORTIE,0)+COALESCE(RC,0))) OVER (PARTITION BY IDCLIENT,IDPRODUIT  ORDER BY Date_Operation,ENTTREE,SORTIE)) END  AS ECART
    -------------------------------------------------
    , SUM((COALESCE(ENTTREE,0)+COALESCE(REPORT,0)-COALESCE(SORTIE,0)+COALESCE(RC,0)))   OVER (PARTITION BY IDCLIENT,IDPRODUIT  ORDER BY Date_Operation,ENTTREE,SORTIE) AS ETAT_STOCK
    from [dbo].[VGESTIONSORTIESTATIONS] )
     
    SELECT  Date_Operation
    ,IDCLIENT
    ,IDPRODUIT
    ,NumeroBon
    ,ENTTREE
    ,INDEX_OUVERTURE
    ,INDEX_FERMETURE
    ,SORTIE
    ,RC
    ,REPORT
    ,JAUGE
    ,ECART
    ------- détermination de ETAT_STOCK en fonction de la colonne ECART --------
    , SUM((COALESCE(ENTTREE,0)+COALESCE(REPORT,0)-COALESCE(SORTIE,0)+COALESCE(RC,0))+COALESCE(ECART,0))   OVER (PARTITION BY IDCLIENT,IDPRODUIT  ORDER BY Date_Operation,ENTTREE,SORTIE) AS ETAT_STOCK
    -----------------------------------------------------------------------------------
    FROM SOLDE 
    WHERE   Date_Operation!='' AND (ENTTREE!='' OR REPORT!='' OR SORTIE!='' OR RC!='' OR ECART!='')AND IDCLIENT='CL17' AND IDPRODUIT='SUP01'
    avec cette requête je souhaite déterminer l'état stocks en fonction de la colonne 'ECART' tel-que vous voyez sur la pièce jointe
    Nom : etatstocks.PNG
Affichages : 122
Taille : 54,1 Ko
    exemple en suivant l'ordre de calcul
    32350-440.75=31909.25;
    31909.25-550.36=31358.89;
    et lorsque la colonne 'JAUGE' est supérieur à 0,
    31200-31358.89=-158.88;
    l'écart étant différent de 0,
    31358.89-158.88-677.58=30522.42;
    30522.42-831.36=29690.56;
    29690.56-1458.049=28232.511;
    mais le résulta présente plutôt -191.38
    or à partir de cette ligne l'écart devrai être égale à -32.511;
    et le processus devrais continuer ainsi. Donc mois je pense que le problème vient de la colonne 'ECART' mais comment corrigé se problème?

Discussions similaires

  1. Réponses: 2
    Dernier message: 18/09/2017, 07h26
  2. Requête récursive CTE avec une condition à vérifier
    Par saylios dans le forum Développement
    Réponses: 2
    Dernier message: 04/11/2016, 14h48
  3. Afficher le résultat d'une requête avec des côtes
    Par sweet_hell dans le forum Langage SQL
    Réponses: 4
    Dernier message: 27/10/2006, 10h32
  4. problème de requête avec jointures
    Par tinhat dans le forum Requêtes
    Réponses: 7
    Dernier message: 11/08/2003, 10h33
  5. Problème dans requête avec count()
    Par BadFox dans le forum Requêtes
    Réponses: 3
    Dernier message: 08/07/2003, 18h02

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