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

Langage SQL Discussion :

Requête SQL avec groupement dynamique


Sujet :

Langage SQL

  1. #1
    Futur Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 17
    Points : 8
    Points
    8
    Par défaut Requête SQL avec groupement dynamique
    Salut,

    Je suis en train de développer un requête assez complexe et j'ai grandement besoin de votre aide.

    En effet je dois calculer la marge de certains produits, mais voila mon problème découpé:

    * Si l'article a déja été acheté en 2006, il fauderait faire la moyenne pondérée de tous les prix d'achat de cet article pour l'année 2006, pour déterminer le prix d'achat de l'article
    * Sinon (l'article n'a pas été acheté en 2006), dans ce cas le prix d'achat de cet article sera le prix d'achat du dernier achat effectué dans la plage de date allant de 2005 à 2000 voir moins si des achats ont été effectué même avant.

    Je ne sais pas comment procéder, j'ai pensé à la clause conditionnelle CASE, mais je ne m'en sors pas.

    Je rappèle que je travaille sous SQL Server 2000.

    Merci sincérement pour toutes vos réponses.
    A+

  2. #2
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 737
    Points
    11 737
    Par défaut
    je te conseille plutôt une Union :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT produit, moyenne pondérée
    FROM...
    WHERE YEAR(date_achat) = 2006
    UNION ALL
    SELECT produit, prix dernier achat
    FROM...
    WHERE YEAR(date_achat) < 2006
    C'est difficile d'aller plus loin sans connaître ton modèle ni ta pondération.

  3. #3
    Futur Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 17
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par Antoun
    je te conseille plutôt une Union :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT produit, moyenne pondérée
    FROM...
    WHERE YEAR(date_achat) = 2006
    UNION ALL
    SELECT produit, prix dernier achat
    FROM...
    WHERE YEAR(date_achat) < 2006
    C'est difficile d'aller plus loin sans connaître ton modèle ni ta pondération.
    Merci bcp,

    Je vais essayer, si ça marche pas je t'expliquerai plus le modèle.
    A+

  4. #4
    Futur Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    17
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 17
    Points : 8
    Points
    8
    Par défaut Please Help
    INTERSECT n'existe pas en SQL Server 2000.
    Ce qui compromet sérieusement tout ce que j'avais commencé à faire, quelqu'un connait un équivalent.
    En fait je comprends pas pourquoi UNION existe mais pas INTERSECT???

  5. #5
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Points : 11 737
    Points
    11 737
    Par défaut
    parce l'INTERSECT peut être facilement remplacé par un EXISTS, voire même un INNER JOIN, tandis que l'union est irremplaçable.

Discussions similaires

  1. requête sql avec clause INNER JOIN
    Par new_wave dans le forum Langage SQL
    Réponses: 1
    Dernier message: 12/08/2005, 15h47
  2. Requête SQL avec une réponse unique
    Par Glutinus dans le forum Langage SQL
    Réponses: 5
    Dernier message: 06/07/2005, 16h35
  3. Problème de requête SQL avec instruction TRANSFORM
    Par Nosper dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 21/06/2005, 16h15
  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