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: renvoyer le prix des articles d'une facture au moment de sa création


Sujet :

Requêtes et SQL.

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Points : 198
    Points
    198
    Par défaut Requête: renvoyer le prix des articles d'une facture au moment de sa création
    Bonjour à tous et merci d'avance pour votre aide.

    Comme indiquer dans le titre, à l'aide d'une requête.
    J'aimerais retrouver le prix des articles qui compose une facture au moment de sa création.

    Nom : Capture.PNG
Affichages : 214
Taille : 9,9 Ko

    • invoices: table des factures avec date de création
    • orders: commande attaché à la facture et aux produits commandés
    • products: table des produits
    • prices: table des prix des produits avec date de création


    Deux conditions pour extraire le prix correspondant:
    prices.created doit être une date inférieur à invoices.created
    prices.created doit être la date la plus proche de invoices.created

    Donc mon raisonnement est posé, en espérant qu'il soit juste.
    En pratique, c'est plus compliqué. J'ai essayé plusieurs choses, mais sans résultat.
    Voici l'était de ma commande SQL, je suis loin du résultat final

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT orders.id_product, prices.price, prices.created, Max(prices.created) AS MaxDecreated
    FROM orders INNER JOIN prices ON orders.id_product = prices.id_product
    GROUP BY orders.id_product, prices.price, prices.created;
    Merci à tous pour votre temps et votre aide.

  2. #2
    Expert confirmé Avatar de nico84
    Homme Profil pro
    Consultant/développeur ERP
    Inscrit en
    Mai 2008
    Messages
    3 108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant/développeur ERP
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2008
    Messages : 3 108
    Points : 5 231
    Points
    5 231
    Par défaut
    Bonjour,

    La requete est bien plus compliquée que ça... 2 solutions :
    - créer une fonction get_price(id_produit, date_prix) qui renvoie le prix voulu et appeler cette fonction dans le select - solution la plus souple mais qui peut prendre du temps d'exécution
    - écrire une requête à 3 étages :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    select date_fac, id_produit, (select max(prix) from base_prix b where b.id_produit=f.id_produit and b.date_prix<=f.date_fac and b.date_prix=(select max(x.date_prix) from base_prix x where x.id_produit=f.id_produit and x.date_prix<=f.date_fac)) as prix_ok
    from facture f where id_facture=...
    PS : appeler toutes les clés "id" et toutes les dates "created" ça va pas faciliter le boulot à terme...

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    477
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 477
    Points : 198
    Points
    198
    Par défaut
    Merci @Nico84 , ton aide m'est précieuse.
    Je vais regarder ça de plus prés ce soir.

Discussions similaires

  1. Réponses: 1
    Dernier message: 24/08/2009, 18h20
  2. [Joomla!] Cherche Module qui fait défiler des articles d'une catégorie
    Par Alcius dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 1
    Dernier message: 12/08/2009, 13h35
  3. Réponses: 3
    Dernier message: 19/05/2008, 10h36
  4. Requête donnant la liste des champs d'une table
    Par laurentSc dans le forum Débuter
    Réponses: 2
    Dernier message: 16/02/2008, 21h08

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