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 MySQL Discussion :

Utiliser if ou case ?


Sujet :

Requêtes MySQL

  1. #1
    Membre confirmé Avatar de Christophe Charron
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2005
    Messages
    920
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2005
    Messages : 920
    Points : 606
    Points
    606
    Par défaut Utiliser if ou case ?
    Bonjour,
    je m'attendais à avoir, pour les 2 requêtes suivantes, le même résultat.
    Or il n'en est rien.
    Quelle est la bonne maniere de procéder ? Sachant, que pour une question d'évolutivité, j'aurais tendance à vouloir utiliser la syntaxe case, permettant de gérer plus de conditions de manière plus lisible...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Select if(f4.choix_cleunik=-110112,round(sum((qte*pu*1)*(1-(f1.remise_taux/100))),0),round(sum((qte*pu*-1)*(1-(f1.remise_taux/100))),0)) as z01,f2.act_cleunik as z02 from _faccli_lignes f1,_acteurs f2,_faccli_entetes f3,_actions f4 where f4.action_cleunik=f3.action_cleunik and f2.act_cleunik=f3.act_cleunik and f1.commercial_cleunik=f3.commercial_cleunik and f2.typeacteur=110003 and (dateheure_confirm between '19610123' and '20610123') group by z02 order by z01 desc limit 12
    Copie écran du résultat visible ici http://test03.christophe-charron.org..._select_if.PNG
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Select round(sum((qte*pu*(case f4.choix_cleunik WHEN -110112 THEN 1 ELSE -1 END))*(1-(f1.remise_taux/100))),0) as z01,f2.act_cleunik as z02 from _faccli_lignes f1,_acteurs f2,_faccli_entetes f3,_actions f4 where f4.action_cleunik=f3.action_cleunik and f2.act_cleunik=f3.act_cleunik and f1.commercial_cleunik=f3.commercial_cleunik and f2.typeacteur=110003 and (dateheure_confirm between '19610123' and '20610123') group by z02 order by z01 desc limit 12
    Copie écran du résultat visible ici http://test03.christophe-charron.org...elect_case.PNG

  2. #2
    Membre confirmé Avatar de Christophe Charron
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2005
    Messages
    920
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2005
    Messages : 920
    Points : 606
    Points
    606
    Par défaut
    Pour information, c'est la seconde requête, celle avec le "case" qui renvoie le bon résultat. Par contre, j'aimerais bien que l'on m'explique pourquoi car cela remet en cause ma confiance dans le "if"!!!

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

Discussions similaires

  1. utilisation d'un case dans un where
    Par stephyugh dans le forum Langage SQL
    Réponses: 3
    Dernier message: 31/10/2007, 18h31
  2. utilisation de Select Case
    Par Mounamidou dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 03/10/2007, 18h39
  3. Utilisation de Use Case
    Par Promeneur dans le forum Cas d'utilisation
    Réponses: 2
    Dernier message: 21/11/2006, 17h42
  4. [Oracle]utilisation d'un CASE
    Par magic charly dans le forum Langage SQL
    Réponses: 5
    Dernier message: 25/04/2006, 17h30
  5. [Debutant] URL utilisable depuis une case d'un tableau de BD
    Par Marc_3 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 03/04/2005, 20h06

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