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 avec date donne un résultat faux


Sujet :

Requêtes et SQL.

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 15
    Points : 5
    Points
    5
    Par défaut Requête avec date donne un résultat faux
    Bonsoir,

    J'ai créé une petite application en prenant comme exemple "les comptoirs 2007" que j'ai adapté à mes besoins. Tout fonctionne bien sauf une requête qui doit me permettre de faire un état comparatif entre les quantitées achetées et les quantitées vendues en fonction des dates que l'on souhaite. Sans les dates cela fonctionne. Cela fait un mois que je retourne dans tous les sens ce problème.
    J'ai essayé : la requête simple, l'annalyse croisée, la non corespondance, la requête de création de table parce que j'ai vu dans le forum qu'il fallait faire une table "mouvement". Je n'ai pas trouvé la solution à ce que je cherche ou alors j' ai tellement lu de post et de tuto que je suis passée à côté.

    Voici ci après le code que j'ai utilisé. Si quelqu'un pouvait me donner une piste.



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT Produits.ID AS [Réf produit], Produits.[Nom du produit], Produits.[Code du produit], Nz([Qté achetée],0) AS [Quantité achetée], Nz([Quantité vendue],0) AS [Qté vendue], [Quantité achetée]-[Qté vendue] AS [Quantité en stock], vente.[Date de création de la transaction], vente.Année, vente.Mois, vente.[Nom du mois], Achat.[Date de création de la transaction], Achat.Année, Achat.Mois, Achat.[Nom du mois]
    FROM Achat INNER JOIN (vente INNER JOIN Produits ON vente.[Réf produit] = Produits.ID) ON Achat.[Réf produit] = Produits.ID;

  2. #2
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    122
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2010
    Messages : 122
    Points : 172
    Points
    172
    Par défaut
    Salutations,

    Vous diets que votre requête ne fonctionne pas avec les dates mais pourriez-vous être plus précise ? La requête est exécutée et renvoie un résultat faux, ou la requête n'est pas exécutée et retourne un message d'erreur ?

    Si elle s'exécute bien, il peut s'agir d'un problème d'interprétation des dates. Avez-vous essayer d'utiliser la fonction Cdate ?

    Cordialement,

  3. #3
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 755
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 755
    Points : 57 602
    Points
    57 602
    Billets dans le blog
    42
    Par défaut
    Bonjour à tous,

    Citation Envoyé par aurel77310
    …en fonction des dates que l'on souhaite.
    En fait, tu veux la somme des quantités achetées regroupées par produit et par mois (idem pour quantités vendues).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Produit		qtte achat	qtteVente	Mois/Année
    Torchon	          30		     25		Janvier 2010
    Torchon	          20		     15		Février 2010
    Serviette         40		     35		Janvier 2010
    …
    30 torchons achetés en Janvier pour 25 vendus, 20 achetés pour 15 vendus en Février, etc…

    C’est bien ça ?

    Citation Envoyé par aurel77310
    …j'ai vu dans le forum qu'il fallait faire une table "mouvement"...
    Tu peux effectivement considérer de manière plus générale qu’[Achat] et [Vente] sont des [Transaction] :
    Transaction(idTransaction, DateTransaction, #RefProduit, qtteTransaction, TypeTransaction)

    TypeTransaction=Achat ou Vente.

    Tout dépend des contraintes de l’application (en particulier si tu as des relations entre les transactions et d’autres tables comme Livraison, Commande, Facture ou autres).

  4. #4
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 15
    Points : 5
    Points
    5
    Par défaut
    Bonjour et merci à tous les deux,

    C'est tout à fait cela f-leb, j'ai réussi à le faire pour quantitée achetée et quantitées vendues mais si je rajoute les dates le résultat est comme suit:

    Exemple:

    J'ai acheté 10 torchons le 10/07/2010

    j'ai vendu 2 torchons le 12/07/2010

    j'ai vendu 3 torchons le 14/07/2010

    Le résultat devrait me donner:

    10 torchons achetés en juillet 2010
    5 torchons vendus en juillet 2010

    or j'ai

    10 torchons achetés en juillet 2010
    10 torchons achetés en juillet 2010
    2 torchons vendus en juillet 2010
    3 torchons vendus en juillet 2010

    en fait il me mets autant de ligne en qté achetée que j'ai de ligne en qte vendu au lieu de me faire un regroupement.

  5. #5
    Invité
    Invité(e)
    Par défaut
    bonjour,

    en fait il me mets autant de ligne en qté achetée que j'ai de ligne en qte vendu au lieu de me faire un regroupement.
    pour faire un regroupement, utiliser la clause <GROUP BY> dans la requete.

  6. #6
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 755
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 755
    Points : 57 602
    Points
    57 602
    Billets dans le blog
    42
    Par défaut
    Bonjour,

    Une proposition en deux étapes…

    1°) constituer un calendrier avec la requête R_Calendrier:

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT DISTINCT * FROM 
    (
      SELECT 
      format([Date de création de la transaction],"mmmm yyyy") as moisAnnee
      FROM Achat
     
      UNION
     
      SELECT 
      format([Date de création de la transaction],"mmmm yyyy") as MoisAnnee
      FROM Vente
    ) ;


    2°) la requête principale :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    SELECT DISTINCT 
    Produits.ID, 
    Produits.[Nom du produit], 
    Produits.[Code du produit], 
    R_Calendrier.moisAnnee,
     (SELECT nz(Sum([Qté achetée]),0) FROM Achat A 
        WHERE format(A.[Date de création de la transaction],"mmmm yyyy")=R_Calendrier.moisAnnee 
        AND A.[Réf produit]=Produits.ID) AS qtteAchetée, 
     
    (SELECT nz(Sum([Quantité vendue]),0) FROM Vente V 
      WHERE format(V.[Date de création de la transaction],"mmmm yyyy")=R_Calendrier.moisAnnee
      AND V.[Réf produit]=Produits.ID) AS qtteVendue
     
    FROM Produits, R_Calendrier;

    A tester…

  7. #7
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 15
    Points : 5
    Points
    5
    Par défaut
    Bonjour,

    Merci pour ces réponses. Je test et je reviens vous dire si cela fonctionne.

  8. #8
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 15
    Points : 5
    Points
    5
    Par défaut
    Rebonjour,

    J'ai essayé ta solution f-leb mais le résultat me retourne des 0 pour toutes les lignes de quantitées achetées et de Quantitées vendues.

    Par ailleurs et j'en suis désolée mais je me suis mal expliquée. En fait j'aurai souhaité faire à partir de la requête un état qui ressemble à celui que je joints en pièce jointe. Celui là fonctionne mais sans le choix des dates. Pour l'exemple j'ai repris la liste des produits de la base " les comptoirs"
    Images attachées Images attachées

  9. #9
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 15
    Points : 5
    Points
    5
    Par défaut
    Pour compléter mon précédent message je joints le code.
    SELECT Produits.ID AS [Réf produit], Produits.[Nom du produit], Produits.[Code du produit], Nz([Qté achetée],0) AS [Quantité achetée], Nz([Quantité vendue],0) AS [Qté vendue], [Quantité achetée]-[Qté vendue] AS [Quantité en stock]
    FROM ((((Produits LEFT JOIN [Inventaire vendu] ON Produits.ID = [Inventaire vendu].[Réf produit]) LEFT JOIN [Inventaire acheté] ON Produits.ID = [Inventaire acheté].[Réf produit]) LEFT JOIN [Inventaire en attente] ON Produits.ID = [Inventaire en attente].[Réf produit]) LEFT JOIN [Inventaire en commande] ON Produits.ID = [Inventaire en commande].[Réf produit]) LEFT JOIN [Produits en livraison différée] ON Produits.ID = [Produits en livraison différée].[Réf produit]
    WHERE (((Nz([Qté achetée],0))>0));

  10. #10
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 15
    Points : 5
    Points
    5
    Par défaut
    Rebonjour

    J'ai simplifié le code, beaucoup de choses qui ne servaient pas pour ma requête.
    SELECT Produits.ID AS [Réf produit], Produits.[Nom du produit], Produits.[Code du produit], Nz([Qté achetée],0) AS [Quantité achetée], Nz([Quantité vendue],0) AS [Qté vendue], [Quantité achetée]-[Qté vendue] AS [Quantité en stock]
    FROM (Produits LEFT JOIN [Inventaire vendu] ON Produits.ID = [Inventaire vendu].[Réf produit]) LEFT JOIN [Inventaire acheté] ON Produits.ID = [Inventaire acheté].[Réf produit]
    WHERE (((Nz([Qté achetée],0))>0));

  11. #11
    Responsable Arduino et Systèmes Embarqués


    Avatar de f-leb
    Homme Profil pro
    Enseignant
    Inscrit en
    Janvier 2009
    Messages
    12 755
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 12 755
    Points : 57 602
    Points
    57 602
    Billets dans le blog
    42
    Par défaut
    Bonjour,

    Citation Envoyé par aurel77310
    Par ailleurs et j'en suis désolée mais je me suis mal expliquée.
    Pourtant, il me semble que je ne suis pas loin du résultat souhaité (à part la mise en page). Voici ce que j’ai réussi à obtenir avec les requêtes du message #6 :


    Citation Envoyé par aurel77310
    Celui là fonctionne mais sans le choix des dates…
    Tu peux créer un formulaire de sélection du mois et de l’année qui modifiera la propriété "filtre" de l’état (macro ou VBA) avant son lancement.
    Dans mon cas, ça donnerait un truc du style, Filtre : [moisAnnee]='janvier 2010'.
    Ils font comme ça dans la base "Comptoirs", non ?

    J’ai du mal à te suivre…

    Citation Envoyé par aurel77310
    mais le résultat me retourne des 0 pour toutes les lignes de quantitées achetées et de Quantitées vendues.
    J’ai quelques lignes de 0 aussi, mais c’est volontairement qu’elles apparaissent :
    - Le produit Z qui n’a eu aucun un achat, ni aucune vente sur la période Janvier-Février;
    - Le produit Y qui n’a eu aucun un achat, ni aucune vente en Février ;
    Ces lignes de 0 doivent-elles disparaître de l’état ?

    S’il n’y a que des 0, c’est qu’il y a probablement une erreur quelque part dans l’écriture des requêtes. Est-ce que la requête R_Calendrier seule retourne les bons résultats ?
    Sinon, montre-nous comment tu as adapté le code en le postant ici.

  12. #12
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 15
    Points : 5
    Points
    5
    Par défaut
    Bonjour,

    Erreur d'interprétation, je faisais la requête à partir des requêtes "achat" et "vente" et donc cela me donnait un résultat avec que des zéro. J'ai fais deux requêtes de création de table, une table achat et une table vente et j'ai reprise ton code qui cette fois me retourne le résultat que je te joints en pièce jointe. Il ne me reste plus qu'a réaliser le filtre et surtout une bonne mise en page et c'est bon. Merci beaucoup f-leb sans toi je n'y serais pas arrivée. Continu à aider ceux qui demande de l'aide, on a besoin de personne comme toi.
    Images attachées Images attachées

Discussions similaires

  1. Problème résultat requête avec date
    Par franck10 dans le forum Requêtes
    Réponses: 5
    Dernier message: 06/12/2011, 11h37
  2. Pb de requête avec date
    Par tedparker dans le forum Requêtes et SQL.
    Réponses: 9
    Dernier message: 24/07/2006, 10h57
  3. Réponses: 4
    Dernier message: 13/02/2006, 18h58
  4. Problème de requête avec dates
    Par charleshbo dans le forum Access
    Réponses: 4
    Dernier message: 08/02/2006, 00h17
  5. Requête avec dates
    Par skyman272 dans le forum Access
    Réponses: 11
    Dernier message: 30/01/2006, 10h16

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