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 :

[Access] OledbC problème de Left Outer JOIN


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2019
    Messages
    173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 27
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2019
    Messages : 173
    Points : 67
    Points
    67
    Par défaut [Access] OledbC problème de Left Outer JOIN
    Bonjour,

    J'ai un petit soucis, j'interroge plusieurs tables: Nom : MLD_5.0.PNG
Affichages : 361
Taille : 45,7 Ko.
    Je voudrais récupérer les organes qui n'ont pas d'association dans la tables rle_orgeq, table qui sert uniquement à voir à dans quels équipements il se trouvent.
    Voici ma requête utilisé en C#:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    "SELECT  table_organe.id,table_serie.Serie,table_equipement.Lieux,table_famille.Famille,table_organe.Libelle,table_organe.Description,table_organe.Symbole " +
                                 " FROM ((((table_organe)" +
                                 " LEFT  OUTER JOIN [rle_orgeq] ON [table_organe].[id] = [rle_orgeq].[idOrgane])" +
                                 " LEFT  JOIN [table_equipement] ON [rle_orgeq].[idEquipement] = [table_equipement].[id]) " +
                                 " LEFT  JOIN table_famille ON table_organe.Famille= table_famille.ID)" +
                                 " LEFT  JOIN table_serie ON table_organe.idSerie = table_serie.id" +
                                 " ORDER BY Libelle"
    J'ai lu sur d'autres topic ou forum que le OUTER s'annulait si il y avait une close where dans la requête, mais ici je n'en ai pas... j'ai essayé sans le ORDER, rien n'y fait...
    J'ai essayé de mettre le outer en dernier avant le ORDER...
    Si quelqu'un à une idée ^^"

    Merci d'avance bonne journée.

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 736
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 736
    Points : 52 448
    Points
    52 448
    Billets dans le blog
    5
    Par défaut
    Il vous manque juste un WHERE :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    SELECT table_organe.id,table_serie.Serie,table_equipement.Lieux,
           table_famille.Famille,table_organe.Libelle,table_organe.
    	   "Description", table_organe.Symbole
    FROM   table_organe
           LEFT  OUTER JOIN [rle_orgeq]        ON [table_organe].[id] = [rle_orgeq].[idOrgane]
           LEFT  OUTER JOIN [table_equipement] ON [rle_orgeq].[idEquipement] = [table_equipement].[id]
           LEFT  OUTER JOIN table_famille      ON table_organe.Famille= table_famille.ID
           LEFT  OUTER JOIN table_serie        ON table_organe.idSerie = table_serie.id
    WHERE  [rle_orgeq].[idOrgane] IS NULL
    ORDER  BY Libelle
    La colonne intitulée "Description" pose problème. C'est un mot réservé du SQL comme SELECT ou JOIN. Entourez là de guillemets.

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

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

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 188
    Points : 12 744
    Points
    12 744
    Par défaut
    Bonjour,
    Tu fais une jointure externe, mais tu ne filtres pas la requête.
    Donc tu récupères tous les lignes de table_organe, et les éventuelles lignes de rle_orgeq qui sont liées.
    Or si tu ne veux que les lignes de table_organe sans lien avec les lignes de rle_oregeq, il faut ajouter un filtre dans le where:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    …
    where rle_oregeq.idorgane is null

    Tatayo.

  4. #4
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2019
    Messages
    173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 27
    Localisation : France, Aube (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2019
    Messages : 173
    Points : 67
    Points
    67
    Par défaut
    Merci à vous deux, le problème n'était pas là, la requête fonctionnait belle et bien, l'erreur se trouvait sur le filtre du datatable ou je stockais les données.
    J'ai des combobox pour filtrer le Dgv et je n'avais pas pris en compte quand le champ lieux ou famille était null....
    J'ai du rajouter un string Format
    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
    16
    17
    18
    19
    20
    21
    22
     private void comboBoxEquipement_SelectedIndexChanged(object sender, EventArgs e)
            {
                try
                {
                    if(string.IsNullOrEmpty(comboBoxEquipement.Text))
                    {
                        (dataGridViewOrgane.DataSource as DataTable).DefaultView.RowFilter = string.Format(
                        "Serie LIKE '%{0}%' AND Lieux IS Null AND Famille LIKE '%{2}%'AND (Libelle LIKE '%{3}%' OR Symbole LIKE '{4}%')"
                        , comboBoxSerie.Text, comboBoxEquipement.Text, comboBoxFamilleOrgane.Text, textBoxOrganeSymbole.Text, textBoxOrganeSymbole.Text);
                    }
                    else
                    {
                        (dataGridViewOrgane.DataSource as DataTable).DefaultView.RowFilter = string.Format(
                          "Serie LIKE '%{0}%' AND Lieux LIKE '%{1}%'  AND Famille LIKE '%{2}%'AND (Libelle LIKE '%{3}%' OR Symbole LIKE '{4}%')"
                          , comboBoxSerie.Text, comboBoxEquipement.Text, comboBoxFamilleOrgane.Text, textBoxOrganeSymbole.Text, textBoxOrganeSymbole.Text);
     
                    }
                }
                catch
                {
     
                }
    Voilà voilà ^^" problème résolu.

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

Discussions similaires

  1. Problème dans left outer join
    Par aymen007 dans le forum SQL
    Réponses: 1
    Dernier message: 21/05/2008, 13h03
  2. problème avec LEFT OUTER JOIN
    Par tofque dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 06/03/2008, 12h57
  3. Problème de left outer join avec Ibatis
    Par sarsipius dans le forum JDBC
    Réponses: 1
    Dernier message: 28/02/2008, 15h51
  4. problème de LEFT OUTER JOIN
    Par Smix007 dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 25/07/2007, 19h54
  5. Problème avec left outer join
    Par jgfa9 dans le forum Requêtes
    Réponses: 1
    Dernier message: 22/08/2005, 22h07

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