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

Développement SQL Server Discussion :

Requete SQL avec CASE IN WHEN


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2018
    Messages
    150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2018
    Messages : 150
    Par défaut Requete SQL avec CASE IN WHEN
    Bonjour,
    voici la requete que j'essaye d'écrire mais le CASE statement est incorrect :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT        dbo.Q_PORCS.PO_DATE_ABAT, dbo.Q_PORCS.PO_NUM_TUE, dbo.Q_PORCS.PO_H_PESEE, dbo.Q_LOTS.LO_TATOU_ELEVAGE, dbo.Q_LOTS.LO_QUALITE, dbo.Q_PORCS.PO_FRAPPE, dbo.Q_LOTS.LO_PORC, 
                             dbo.Q_PORCS.PO_ABC, dbo.Q_PORCS.PO_MFS, dbo.Q_PORCS.PO_TMP / 10 AS TMP, dbo.Q_PORCS.PO_P1 / 10 AS P1, dbo.Q_PORCS.PO_P1_FROID / 10 AS P1_FROID, dbo.Q_PORCS.PO_OBS1, 
                             dbo.Q_PORCS.PO_OBS2, dbo.Q_PORCS.PO_OBS3, dbo.Q_PORCS.PO_P2 / 10 AS P2, dbo.Q_PORCS.PO_P2_FROID / 10 AS P2_FROID, dbo.Q_PORCS.PO_GPT_NOM, dbo.Q_PORCS.PO_QUALITE, 
                             dbo.Q_LOTS.LO_USER_CODE
    FROM            dbo.Q_PORCS INNER JOIN
                             dbo.Q_LOTS ON dbo.Q_PORCS.PO_FRAPPE = dbo.Q_LOTS.LO_TATOUT_LOT
    WHERE        (dbo.Q_PORCS.PO_QUALITE <> dbo.Q_LOTS.LO_QUALITE) OR
                             (dbo.Q_PORCS.PO_OBS1 in (CASE WHEN LO_QUALITE = 'F' THEN 47,99 END))
    Comment puis-je corriger ce code ?
    Merci

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    Sans doute est-ce cela que tu voulais écrire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    WHERE   dbo.Q_PORCS.PO_QUALITE <> dbo.Q_LOTS.LO_QUALITE
        OR  (   dbo.Q_LOTS.LO_QUALITE = 'F'
            AND dbo.Q_PORCS.PO_OBS1 in (47,99)
            )
    NB : Les parenthèses ne sont pas obligatoires compte-tenu de la précédence des opérateurs mais améliorent ici la lisibilité du code.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

Discussions similaires

  1. [2016] Vue SQL avec CASE WHEN imbriqués
    Par BLNHRDT dans le forum Développement
    Réponses: 5
    Dernier message: 12/07/2018, 16h55
  2. Requete sql avec les CASE
    Par SOPSOU dans le forum InterBase
    Réponses: 4
    Dernier message: 17/08/2010, 10h29
  3. REQUETE SQL AVEC HAVING
    Par juju_77 dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 05/08/2005, 09h49
  4. Probleme de requete SQL avec un champs date
    Par ju360modena dans le forum ASP
    Réponses: 5
    Dernier message: 16/06/2005, 11h18
  5. [JDBC] retour de requete sql avec valeur NULL
    Par maxxou dans le forum JDBC
    Réponses: 3
    Dernier message: 13/09/2004, 14h40

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