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

Requêtes et SQL. Discussion :

Requête SQL avec SUM en fonction d'un attribut [AC-2003]


Sujet :

Requêtes et SQL.

  1. #1
    Futur Membre du Club
    Inscrit en
    Novembre 2005
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 13
    Points : 8
    Points
    8
    Par défaut Requête SQL avec SUM en fonction d'un attribut
    Bonjour à tous,

    Je suis un peu désespéré car je ne trouve pas la solution, raison pour laquelle je viens vous solliciter sur le forum.
    Je vous plante le décors : j'ai une base de données Access, et je dois calculer des quantités de titre en fonction d'un attribut.
    Je vous dessine un mouton exemple :
    Imaginons que j'ai 3 fonds dans ma base de données (il s'agit d'OPCVM).
    Chaque fond a trois "ordres". Prenons par exemple le fond A :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Fond A : 
    Rachat de 1 quantité
    Souscription de 3 quantités
    Rachat de 1 quantité
    Sachant, qu'en plus de ces ordres qui sont sur une table, je peux également avoir une autre quantité sur une autre table.

    Je dois faire une requête faisant la chose suivante, pour chaque fond :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SUM(quantité de toutes les souscription) + (SUM quantité sur la table annexe éventuelle) - SUM(quantité de tous les rachats)
    De plus, dernière petit subtilité, je dois le faire en fonction du portefeuille (autrement dit, l'attribut "pf" ou "numPF").
    La requête que j'ai écrite est la suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT isin, numPF
    FROM Ordre o
    WHERE o.isin NOT IN (SELECT isin FROM ValeurLiquidative WHERE format([dateFichier], "mm-yyyy") = format(CDATE("01/" & [Mois ?] & "/" & [Année?]), "mm-yyyy"))
    GROUP BY isin, numPF
    HAVING ((SELECT SUM(quantite) FROM Ordre o1 WHERE o1.isin = o.isin AND o1.numTO = 1 AND o1.numPF = o.numPF) + IIF(ISNULL((SELECT SUM(quantiteInit) FROM Init i WHERE i.isin = o.isin AND i.pf = o.numpf)), 0, (SELECT SUM(quantiteInit) FROM Init i WHERE i.isin = o.isin AND i.pf = o.numpf)) - (SELECT SUM(quantite) FROM Ordre o2 WHERE o2.isin = o.isin AND o2.numTO = 2 AND o2.numPF = o.numPF)) <> 0
    Le problème est... Que ma requête ne me retourne rien. L'ajout dans la requête de la partie "isin NOT IN" vérifie également que le fond n'a pas de valeur liquidative dans un mois donné (autrement dit, que la requête ne retourne rien pour le fond spécifié pour le mois). Cette requête marche très bien sans le rajout de celle dans le "HAVING", qui est censée m'enlever les fonds qui ont une quantité de 0 (voir requête).

    Je ne suis pas vraiment sûr d'être clair... Mais si quelqu'un d'entre vous peut m'aider, je suis grandement preneur.

    Merci d'avance

  2. #2
    Futur Membre du Club
    Inscrit en
    Novembre 2005
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 13
    Points : 8
    Points
    8
    Par défaut
    Pour information, celle-ci marche presque :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT isin, numPF, (SELECT SUM(quantite) FROM Ordre o1 WHERE o1.isin = o.isin AND o1.numTO = 1 AND o1.numPF = o.numPF) as Sous, (SELECT SUM(quantiteInit) FROM Init i WHERE i.isin = o.isin AND i.pf = o.numpf) as init, (SELECT SUM(quantite) FROM Ordre o2 WHERE o2.isin = o.isin AND o2.numTO = 2 AND o2.numPF = o.numPF) as Rachats, (IIF(isnull(Sous), 0, Sous) + IIF(isnull(init), 0, init) - IIF(isnull(rachats), 0, rachats)) as 'Quantité détenue'
    FROM Ordre AS o
    WHERE o.isin NOT IN (SELECT isin FROM ValeurLiquidative WHERE format([dateFichier], "mm-yyyy") = format(CDATE("01/" & [Mois ?] & "/" & [Année?]), "mm-yyyy"))
    AND dateReglement <= CDATE("01-" & [Mois ?] & "-" & [Année?])
    GROUP BY isin, numPF
    HAVING (IIF(isnull((SELECT SUM(quantite) FROM Ordre o1 WHERE o1.isin = o.isin AND o1.numTO = 1 AND o1.numPF = o.numPF)), 0, (SELECT SUM(quantite) FROM Ordre o1 WHERE o1.isin = o.isin AND o1.numTO = 1 AND o1.numPF = o.numPF)) + IIF(isnull((SELECT SUM(quantiteInit) FROM Init i WHERE i.isin = o.isin AND i.pf = o.numpf)), 0, (SELECT SUM(quantiteInit) FROM Init i WHERE i.isin = o.isin AND i.pf = o.numpf)) - IIF(isnull((SELECT SUM(quantite) FROM Ordre o2 WHERE o2.isin = o.isin AND o2.numTO = 2 AND o2.numPF = o.numPF)), 0, (SELECT SUM(quantite) FROM Ordre o2 WHERE o2.isin = o.isin AND o2.numTO = 2 AND o2.numPF = o.numPF)))
    La requête me retourne bien les bons fonds, sauf... Ceux qui ont une quantité sur la table annexe... Une idée?

    Edit final

    C'est bon, j'ai trouvé... Un fond peut ne pas avoir eu d'ordre depuis l'initialisation (table annexe), ce qui parait logique qu'elle n'apparaisse pas dans les requêtes précédentes. J'ai donc rajouté un UNION.

    Merci à tous ceux qui ont essayé de m'aider

  3. #3
    Rédacteur/Modérateur

    Avatar de Jean-Philippe André
    Homme Profil pro
    Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Inscrit en
    Juillet 2007
    Messages
    14 630
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Canada

    Informations professionnelles :
    Activité : Architecte Power Platform, ex-Développeur VBA/C#/VB.Net
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2007
    Messages : 14 630
    Points : 34 337
    Points
    34 337
    Par défaut
    Hello,

    si ta problématique de souscriptions rachat est résolue, n'hésite pas à mettre ta requete solution finale

    Et/ou
    à cliquer sur le tag de la conversation

  4. #4
    Futur Membre du Club
    Inscrit en
    Novembre 2005
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 13
    Points : 8
    Points
    8
    Par défaut
    Je ne devais pas être réveillé, je n'arrivais pas à trouver le bouton "résolu"
    Mais c'est fait! Je mettrai le code plus tard, quand je serai retourné sur ce projet en question

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 16/05/2012, 09h48
  2. [AC-2003] Requête SQL avec sélection de dates spécifiques et fonction iif
    Par luckytiger dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 04/03/2010, 11h08
  3. Requête SQL avec UNION, sum et GROUP BY
    Par Guitariff dans le forum Langage SQL
    Réponses: 6
    Dernier message: 03/12/2006, 13h48
  4. requête SQL avec paramètre en vb avec base de donnée SQL srv
    Par dialydany dans le forum VB 6 et antérieur
    Réponses: 5
    Dernier message: 01/02/2005, 10h33
  5. PB requète SQL avec Interbase
    Par missllyss dans le forum InterBase
    Réponses: 2
    Dernier message: 15/07/2003, 11h37

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