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

SQL Oracle Discussion :

CASE avec EXISTS et SELECT


Sujet :

SQL Oracle

  1. #1
    Membre expérimenté
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2014
    Messages
    271
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2014
    Messages : 271
    Par défaut CASE avec EXISTS et SELECT
    Bonjour à tous,

    Dans ma base, certains dossiers son présent dans des tables a mais absents dans des tables b.

    Je voudrais savoir s'il est possible d'avoir un ordre sql qui permet d'avoir pour un dossier les informations de la table a (ZQFF) , puis si ce dossier est présent dans la table b (ZQ62) les informations de la table b, sinon 'titi'.

    Pour le moment j'ai essayé ça sans résultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     select a.SSNUM1, case when exists ( select 1 from ZQ62) then (select b.DATEFF from ZQ62 b where a.nudoss=b.nudoss)  else 'titi' end
    from ZQFF a ;
    Merci

    Hadrien POQUET

  2. #2
    Membre Expert
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2013
    Messages
    2 005
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 2 005
    Par défaut
    Citation Envoyé par had4789 Voir le message
    Pour le moment j'ai essayé ça sans résultat :
    Et c'set quoi le pb? Tu as un message d'erreur ou le résultat n'est pas correct?

  3. #3
    Expert confirmé
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 371
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 371
    Par défaut
    Bonjour,
    Le problème dans la requête est que la sous-requête du EXIST n'est pas corrélée.
    Donc pour moi le résultat est faux.
    Je pense qu'il est plus simple (et plus efficace) de passer par une jointure externe:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    select a.SSNUM1,(case when b.DATEFF is null then 'titi' else b.DATEFF end)
    from ZQFF a
    left outer join ZQ62 b on a.nudoss=b.nudoss

    Tatayo.

  4. #4
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    1/ dateff pouvant être NULL, il faut tester le nudoss
    2/ Attention si dateff est une date, à passer en varchar

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT a.SSNUM1, CASE WHEN b.nudoss IS NULL THEN 'titi' ELSE b.DATEFF END
    FROM ZQFF a, ZQ62 b
    WHERE b.nudoss (+)= a.nudoss;

  5. #5
    Membre Expert
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Février 2012
    Messages
    652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2012
    Messages : 652
    Par défaut
    La requête énoncée ne pourra pas fonctionner en l'état et le contrôle d'existence dans B ne porte sur aucun critère, donc dès qu'un enregistrement existe dedans, cela renverra "True"

    Dans votre cas si vous avez des enregistrements dans une table A et voulez tester l'existence de ce même enregistrement dans une table B, le plus indiqué est de faire une jointure facultative du type :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT A.code. A.Nom, 
      DECODE(B.Code, NULL, 'Titi', B.Nom)
    FROM TableA
      LEFT OUTER JOIN TableB
        ON A.Code = B.Code

  6. #6
    Membre expérimenté
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2014
    Messages
    271
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2014
    Messages : 271
    Par défaut Solution
    Scriuiw , ta solution fonctionne.

    Merci beaucoup

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

Discussions similaires

  1. Comment eviter de faire un Select Case avec beaucoup de valeur
    Par jam92400 dans le forum Macros et VBA Excel
    Réponses: 20
    Dernier message: 05/11/2010, 15h19
  2. Select Case avec plusieurs variables
    Par sphynxounet dans le forum VB.NET
    Réponses: 10
    Dernier message: 10/08/2009, 18h16
  3. Select case avec then qui retourne une variable
    Par dinette dans le forum SQL
    Réponses: 6
    Dernier message: 06/07/2009, 11h03
  4. select case avec if
    Par *kitty* dans le forum VB 6 et antérieur
    Réponses: 24
    Dernier message: 27/11/2008, 15h59
  5. Problème de case avec select
    Par Hirua dans le forum Requêtes
    Réponses: 3
    Dernier message: 20/05/2008, 10h47

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