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

MS SQL Server Discussion :

Fonction LEFT() & IF()


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de JmL40
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    348
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 348
    Par défaut Fonction LEFT() & IF()
    Bonjour,

    Je suis dans une impasse en terme de syntaxe et d'utilisation de la fonction IF et de la fonction LEFT.

    Je pense que le problème n'est pas bien difficile mais je bloque complètement.

    Je souhaiterai exécuter cette requête qui sous MySQL retourne correctement des enregistrements :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT IF(LEFT(TABLE1.COL,3)='XX','XX',LIGNEE_TABLE1.COL) FROM TABLE1
    Sous SQL Server, il semble que la suite de fonction IF + LEFT ne s'utilise pas de cette manière.

    Pouvez-vous m'aider ?

    Merci

    Cordialement

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    IF est (plus ou moins) propriétaire à MySQL.
    En SQL on utilise CASE :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT CASE LEFT(TABLE1.COL,3)
             WHEN 'XX' THEN 'XX'
             ELSE LIGNEE_TABLE1.COL
           END As Col
      FROM TABLE1
    Par contre vous comparez les trois premiers caractères à seulement deux ?
    Ce ne sera jamais vérifié, donc toute votre expression est strictement égale à LIGNEE_TABLE1.COL.

  3. #3
    Membre éclairé Avatar de JmL40
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    348
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 348
    Par défaut
    Bonjour,

    Merci pour votre réponse.

    En effet, la comparaison reviens à retourner la colonne.

    Je compare bien cette colonne avec une suite de trois caractères donc je

    n'aurais de soucis à utiliser la fonction.

    Je vous remercie, je test ....

    Cordialement

  4. #4
    Membre éclairé Avatar de JmL40
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    348
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 348
    Par défaut
    Bonjour,

    Solution adoptée, merci beaucoup pour vos renseignements.

    Cordialement

    JmL40

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

Discussions similaires

  1. Problème fonction LEFT(str,len)
    Par beberd dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 07/11/2006, 18h24
  2. Fonction Left join, Right Join
    Par chandlerbing77 dans le forum Access
    Réponses: 2
    Dernier message: 22/06/2006, 16h36
  3. fonction left
    Par HULK dans le forum Langage SQL
    Réponses: 2
    Dernier message: 27/12/2004, 11h19
  4. fonction left avec sql server 6.5
    Par shake dans le forum Langage SQL
    Réponses: 2
    Dernier message: 29/06/2004, 08h48
  5. Fonction LEFT sur champ de type "text" : méthodes
    Par MatthieuQ dans le forum Langage SQL
    Réponses: 4
    Dernier message: 08/06/2004, 11h15

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