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 :

[DB2] left join


Sujet :

Langage SQL

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    49
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2004
    Messages : 49
    Par défaut [DB2] left join
    bonjour,

    voici une requête que j'utilise
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT ETAB.NS_ETAB_ID, TE_NOM_ETAB , COALESCE(ZONEGEO.TE_NOM_ZGEO, 'p'),   COALESCE(ZONEGEO.CO_TYPE_ZGEO, 'p')
    FROM FASE.ETAB  ETAB
      LEFT JOIN FASE.ETABZONE ETABZONE ON ETAB.NS_ETAB_ID = ETABZONE.NS_ETAB_ID
      LEFT JOIN FASE.ZONEGEO ZONEGEO ON ETABZONE.NS_ZGEO_ID = ZONEGEO.NS_ZGEO_ID
      WHERE    ETAB.NS_ETAB_ID = 1 AND
               ZONEGEO.CO_TYPE_ZGEO LIKE '%'
               AND ZONEGEO.TE_NOM_ZGEO LIKE '%';
    le NS_ETAB_ID existe dans la table FASE.ETAB mais à cause du LEFT join, il n'apparaît pas lors de l'exécution. Ceci vient de la valeur NULL car si j'éxecute
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT ETAB.NS_ETAB_ID, TE_NOM_ETAB , COALESCE(ZONEGEO.TE_NOM_ZGEO, 'p'),   COALESCE(ZONEGEO.CO_TYPE_ZGEO, 'p')
    FROM FASE.ETAB  ETAB
      LEFT JOIN FASE.ETABZONE ETABZONE ON ETAB.NS_ETAB_ID = ETABZONE.NS_ETAB_ID
      LEFT JOIN FASE.ZONEGEO ZONEGEO ON ETABZONE.NS_ZGEO_ID = ZONEGEO.NS_ZGEO_ID
      WHERE    ETAB.NS_ETAB_ID = 1 AND
               ZONEGEO.CO_TYPE_ZGEO IS NULL
               AND ZONEGEO.TE_NOM_ZGEO IS NULL;
    malheureusement, j'ai absolument besoin du like. Si je combine le like avec le IS NULL, je reçois toujours des résultats.

    Or je n'ai besoin que du LIKE.

    Quelqu'un peut-il m'aider?

    merci

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 133
    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 133
    Par défaut
    Il suffit de déplacer ta sélection sur ZONEGEO dans la jointure :
    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
    SELECT    ETAB.NS_ETAB_ID
        ,    TE_NOM_ETAB 
        ,    COALESCE(ZONEGEO.TE_NOM_ZGEO, 'p')
        ,    COALESCE(ZONEGEO.CO_TYPE_ZGEO, 'p') 
    FROM    FASE.ETAB ETAB 
        LEFT JOIN 
            FASE.ETABZONE ETABZONE 
            ON  ETAB.NS_ETAB_ID = ETABZONE.NS_ETAB_ID 
        LEFT JOIN 
            FASE.ZONEGEO ZONEGEO 
            ON  ETABZONE.NS_ZGEO_ID = ZONEGEO.NS_ZGEO_ID 
            AND ZONEGEO.CO_TYPE_ZGEO LIKE '%'
            AND ZONEGEO.TE_NOM_ZGEO LIKE '%'
    WHERE    ETAB.NS_ETAB_ID = 1 
    ;
    La sélection dans le WHERE s'effectue sur les résultats de la jointure.
    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.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    49
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2004
    Messages : 49
    Par défaut
    merci pour ta réponse al1_24, ça fonctionne impec.
    question subsidiaire si je peux :

    est-il possible de créer une vue en laissant naturellement tomber la clause where?

    merci

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 133
    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 133
    Par défaut
    Citation Envoyé par lecitoyen
    est-il possible de créer une vue en laissant naturellement tomber la clause where?
    Que veux-tu dire par là ?
    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.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    49
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2004
    Messages : 49
    Par défaut
    j'ai été trop optimiste, si je mets un paramètre
    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
     
    SELECT    ETAB.NS_ETAB_ID
        ,    TE_NOM_ETAB
        ,    ZONEGEO.TE_NOM_ZGEO
        ,    ZONEGEO.CO_TYPE_ZGEO
    FROM    FASE.ETAB ETAB
        LEFT JOIN
            FASE.ETABZONE ETABZONE
            ON  ETAB.NS_ETAB_ID = ETABZONE.NS_ETAB_ID
        LEFT JOIN
            FASE.ZONEGEO ZONEGEO
            ON  ETABZONE.NS_ZGEO_ID = ZONEGEO.NS_ZGEO_ID
            AND ZONEGEO.CO_TYPE_ZGEO LIKE '%'
            AND ZONEGEO.TE_NOM_ZGEO LIKE '01%'
    WHERE    ETAB.NS_ETAB_ID = 1
    ce query ne doit pas donner de résultat!
    désolé

Discussions similaires

  1. count() dans *plusieurs* LEFT JOIN
    Par silver_dragoon dans le forum Langage SQL
    Réponses: 2
    Dernier message: 28/06/2004, 17h20
  2. LEFT JOIN avec Oracle 8i ne va pas... doit utiliser (+)
    Par loikiloik dans le forum Langage SQL
    Réponses: 10
    Dernier message: 21/04/2004, 16h38
  3. Interbase et left join
    Par Zog dans le forum Bases de données
    Réponses: 4
    Dernier message: 23/03/2004, 08h55
  4. Non coincident MySQL (Left Join)
    Par Remiguel dans le forum Requêtes
    Réponses: 6
    Dernier message: 03/11/2003, 21h25
  5. Export d'une vue avec LEFT JOIN
    Par schnourf dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 22/05/2003, 13h57

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