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 :

Aide amélioration requête


Sujet :

Langage SQL

  1. #1
    Membre habitué Avatar de Jefty
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Décembre 2009
    Messages
    203
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2009
    Messages : 203
    Points : 125
    Points
    125
    Par défaut Aide amélioration requête
    Bonjour à tous,

    Voilà l'analyse:




    La requête:


    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
    SELECT PRESTATION.PRESTATION_ABREGE,
    SUM(CASE WHEN NUTRITION.NUTRITION_CLE = '25000' AND DIET.ORDRE <> 0 THEN (NUTRITION.POURCENTAGE * PLATCOM.QUANTITE_PLAT) END) AS Proteines,
    SUM(CASE WHEN NUTRITION.NUTRITION_CLE = '310' AND DIET.ORDRE <> 0 THEN (NUTRITION.POURCENTAGE * PLATCOM.QUANTITE_PLAT) END) AS Energie_STD,
    SUM(CASE WHEN NUTRITION.NUTRITION_CLE = '31000' AND DIET.ORDRE <> 0 THEN (NUTRITION.POURCENTAGE * PLATCOM.QUANTITE_PLAT) END) AS Glucides_disponibles,
    SUM(CASE WHEN NUTRITION.NUTRITION_CLE = '10200' AND DIET.ORDRE <> 0 THEN (NUTRITION.POURCENTAGE * PLATCOM.QUANTITE_PLAT) END) AS Calcium,
     
    SUM(CASE WHEN NUTRITION.NUTRITION_CLE = '10200' AND DIET.ORDRE <> 0 THEN (NUTRITION.POURCENTAGE * PLATCOM.QUANTITE_PLAT) END) AS Calcium_2,
    SUM(CASE WHEN NUTRITION.NUTRITION_CLE = '311' AND DIET.ORDRE <> 0 THEN (NUTRITION.POURCENTAGE * PLATCOM.QUANTITE_PLAT) END) AS Energie_STD_2,
    SUM(CASE WHEN NUTRITION.NUTRITION_CLE = '31001' AND DIET.ORDRE <> 0 THEN (NUTRITION.POURCENTAGE * PLATCOM.QUANTITE_PLAT) END) AS Glucides_disponibles_2,
    SUM(CASE WHEN NUTRITION.NUTRITION_CLE = '32000' AND DIET.ORDRE <> 0 THEN (NUTRITION.POURCENTAGE * PLATCOM.QUANTITE_PLAT) END) AS Sucres
     
     
    FROM NUTRITION, PLATCOM, DIET, PRESTATION
    WHERE NUTRITION.PLAT_CLE = PLATCOM.PLAT_CLE
    AND DIET.NUTRITION_CLE = NUTRITION.NUTRITION_CLE
    AND PLATCOM.PRESTATION_CLE = PRESTATION.PRESTATION_CLE
    AND PLATCOM.DATE BETWEEN {DateDebut} AND {DateFin}
    AND	PLATCOM.ECOLE_CLE = {ID_Ecole} 
    AND DIET.ORDRE <> 0
    GROUP BY PRESTATION.PRESTATION_ABREGE
    J'ai évité la lecture des 36 "case", j'en ai laissé que 8, pour l'exemple ça suffit largement.

    Mon problème est que la ligne:
    AND DIET.ORDRE <> 0
    n'est pas prise en compte, puisque la requête retourne obligatoirement une ligne par "case".
    Y a t'il un moyen de supprimer une colonne généré par le "case", si celle-ci est lié à un DIET.ORDRE <> 0?

    Je reste à votre disposition pour toute question.
    Merci d'avance,

    Jefty

  2. #2
    Expert éminent
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 170
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 170
    Points : 7 422
    Points
    7 422
    Billets dans le blog
    1
    Par défaut
    Bonjour,

    Je ne comprends pas la moitié de votre problématique.

    Plusieurs choses :
    - Depuis 1992, les jointures son normalisées : utilisez-la bonne syntaxe
    - Le ne comprends pas pourquoi vous avez un filtre DIETE <> 0 dans votre WHERE et qu'il apparaît aussi dans les CASE : c'est l'un ou l'autre, là ça sert à rien
    - Qu'entendez-vous pas "supprimer une colonne" ? Vous ne pouvez pas changer le nombre de colonnes retournées par une requête... Sinon quand y'a deux lignes, tout serait mélangé ! Renvoyez NULL avec vos CASE quand il n'y a pas de données dans ce cas.

  3. #3
    Membre habitué Avatar de Jefty
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Décembre 2009
    Messages
    203
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2009
    Messages : 203
    Points : 125
    Points
    125
    Par défaut
    Le DIET.ORDRE <> 0 dans les "case" renvoi NULL pour les cas où le calcul ne peut pas être fait. Je me retrouve donc avec des colonnes complètes de NULL et d'autres colonnes avec mes SUM et quelques NULL pas gênants. Je voulais donc savoir si on pouvait dégagé ces colonnes le cas où il n'y a que des NULL dedans, mais vous m'avez répondu pour ça, c'est impossible et pas logique.
    Le DIET.ORDRE <> 0 en bas ne sert à rien en effet.

    Par contre je ne vois pas ce que vous entendez par :
    "Renvoyez NULL avec vos CASE quand il n'y a pas de données dans ce cas."
    Est ce que c'est ce que je fais déjà comme expliqué avant, ou vous avez une autre idée?

    Merci.

  4. #4
    Expert éminent
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 170
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 170
    Points : 7 422
    Points
    7 422
    Billets dans le blog
    1
    Par défaut
    Bonjour,

    Il n'y a aucun moyen de changer le nombre de colonnes (la forme du résultat) en fonction des données présentes dans les lignes.

    Donc il faudra faire avec les colonnes nulles.

    C'est à votre outil client de traiter l'affichage ou non des colonnes lorsqu'elles sont complètement nulles ou non.

  5. #5
    Membre habitué Avatar de Jefty
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Décembre 2009
    Messages
    203
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2009
    Messages : 203
    Points : 125
    Points
    125
    Par défaut
    Oui, merci.
    J'ai réussi dailleurs.

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

Discussions similaires

  1. Aide sur Requête SQL
    Par devdev dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 11/05/2005, 12h33
  2. Aide pour requête de Tri assez spécial (Oracle)
    Par Chips dans le forum Langage SQL
    Réponses: 2
    Dernier message: 29/04/2005, 10h56
  3. Besoin d'aide sur requête croisée
    Par keawee dans le forum Access
    Réponses: 7
    Dernier message: 18/11/2004, 09h46
  4. [sqlbaseserver]demande de conseils/aides pour requêtes
    Par GéniuS77 dans le forum Langage SQL
    Réponses: 14
    Dernier message: 18/03/2004, 17h27
  5. Aide pour Requête
    Par Guiche dans le forum Langage SQL
    Réponses: 3
    Dernier message: 13/11/2003, 20h18

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