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 :

Erreur de syntaxe avec des multi [inner join]


Sujet :

Langage SQL

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 36
    Points : 34
    Points
    34
    Par défaut Erreur de syntaxe avec des multi [inner join]
    Bonjour à tous ,

    J'utilise c# pour me connecté à une base de donnée avec Microsoft.Jet.OleDb.4.0;

    quand je lance ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    SELECT TOP 30 `aoaacd`,   (`aoaepr` / `aoadpr`)
        FROM `Tarclient`  INNER JOIN    
    (SELECT `aaaacd` FROM `Article` IN 'C:\\Mpb\\Bdd\\Article.mdb'  
               INNER JOIN    
              (SELECT `CodArt` FROM `StockMag` IN 'C:\\Mpb\\Bdd\\StockMag.mdb' WHERE 1 AND `StockMag`.`StkAS400`>10
              ) `JOIN_StockMag` 
             ON `JOIN_StockMag`.`CodArt` =   `Article`.`aaaacd` WHERE 1 AND `Article`.`aaaana` LIKE '%aaa%' 
    ) `JOIN_Article`
    ON `JOIN_Article`.`aaaacd` =   `Tarclient`.`aoaacd`
     WHERE 1 ORDER BY   (`aoaepr` / `aoadpr`)
    il me sort :
    Une exception non gérée du type 'System.Data.OleDb.OleDbException' s'est produite dans System.Data.dll
    Informations supplémentaires : Erreur de syntaxe dans la clause FROM.


    alors que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT TOP 30 `aoaacd`,   (`aoaepr` / `aoadpr`)  
      FROM `Tarclient`   INNER JOIN    
    (SELECT `CodArt` FROM `StockMag` IN 'C:\\Mpb\\Bdd\\StockMag.mdb' WHERE 1 AND `StockMag`.`StkAS400`>10
    ) `JOIN_StockMag` 
    ON `JOIN_StockMag`.`CodArt` =   `Tarclient`.`aoaacd` 
    WHERE 1 ORDER BY   (`aoaepr` / `aoadpr`)
    Fonctionne bien

    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT TOP 30 `aoaacd`,   (`aoaepr` / `aoadpr`)   
     FROM `Tarclient`   INNER JOIN    
    (SELECT `aaaacd` FROM `Article` IN 'C:\\Mpb\\Bdd\\Article.mdb' WHERE 1 AND `Article`.`aaaana` LIKE '%aaa%' 
    ) `JOIN_Article` 
    ON `JOIN_Article`.`aaaacd` =   `Tarclient`.`aoaacd` 
    WHERE 1 ORDER BY   (`aoaepr` / `aoadpr`)
    aussi


    D'avance merci pour tout aiguillage

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    Voici votre requête remise en forme :
    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
    SELECT TOP 30 `aoaacd`,   (`aoaepr` / `aoadpr`)
    FROM `Tarclient`  
    INNER JOIN    
    (
    	SELECT `aaaacd` 
    	FROM `Article` IN 'C:\\Mpb\\Bdd\\Article.mdb'  
    	INNER JOIN    
    	(
    		SELECT `CodArt` 
    		FROM `StockMag` IN 'C:\\Mpb\\Bdd\\StockMag.mdb' 
    		WHERE 1 
    			AND `StockMag`.`StkAS400`>10
    	) `JOIN_StockMag` ON `JOIN_StockMag`.`CodArt` =   `Article`.`aaaacd` 
    	WHERE 1 
    		AND `Article`.`aaaana` LIKE '%aaa%' 
    ) `JOIN_Article` ON `JOIN_Article`.`aaaacd` =   `Tarclient`.`aoaacd`
    WHERE 1 
    ORDER BY   (`aoaepr` / `aoadpr`)
    Je n'y vois rien d'anormal, hormis ces IN derrière les FROM mais c'est peut-être une syntaxe propre à votre SGBD ou à vos outils de dialogue avec le SGBDR. Et puisque les autres requêtes fonctionnent et comportent la même bizarrerie...

    Cependant, vous pouvez supprimer les clauses WHERE 1 qui sont parfaitement inutiles ! À moins que ce soit encore une nécessité bizarre imposée par vos outils.
    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 TOP 30 `aoaacd`,   (`aoaepr` / `aoadpr`)
    FROM `Tarclient`  
    INNER JOIN    
    (
    	SELECT `aaaacd` 
    	FROM `Article` IN 'C:\\Mpb\\Bdd\\Article.mdb'  
    	INNER JOIN    
    	(
    		SELECT `CodArt` 
    		FROM `StockMag` IN 'C:\\Mpb\\Bdd\\StockMag.mdb' 
    		WHERE  `StockMag`.`StkAS400`>10
    	) `JOIN_StockMag` ON `JOIN_StockMag`.`CodArt` =   `Article`.`aaaacd` 
    	WHERE `Article`.`aaaana` LIKE '%aaa%' 
    ) `JOIN_Article` ON `JOIN_Article`.`aaaacd` =   `Tarclient`.`aoaacd`
    ORDER BY   (`aoaepr` / `aoadpr`)
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 36
    Points : 34
    Points
    34
    Par défaut
    1) Déjà Merci d'avoir répondu

    2)vous pouvez supprimer les clauses WHERE 1 qui sont parfaitement inutiles

    oui vous avez raison (c'est mon programme perso qui les génère)

    3) ces IN derrière les FROM
    ils me permettent d'aller chercher des Tables qui se trouvent dans un autre fichier
    que celui où je suis connecter :

    OleDbConnection conn = new OleDbConnection(
    "Provider=Microsoft.Jet.OleDb.4.0;"
    + "Data Source=C:\\Mpb\\Bdd\\TarClien.mdb"
    );
    _________________________

    en simplifiant juste pour tester :

    ceci fonctionne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT * 
    FROM `Tarclient`
    INNER JOIN   
    (
       SELECT `CodArt` FROM `StockMag` 
       IN 'C:\\Mpb\\Bdd\\StockMag.mdb'
    ) 
    `JOIN_StockMag` 
    ON `JOIN_StockMag`.`CodArt` =   `Tarclient`.`aoaacd` `


    ceci ne fonctionne pas :
    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 *   
    FROM `Tarclient`   
    INNER JOIN    
    (
       SELECT `aaaacd` 
       FROM `Article` IN 'C:\\Mpb\\Bdd\\Article.mdb'  
       INNER JOIN    
       (
          SELECT `CodArt`       FROM `StockMag` 
          IN 'C:\\Mpb\\Bdd\\StockMag.mdb'
        ) 
        `JOIN_StockMag`
       ON `JOIN_StockMag`.`CodArt` =   `Article`.`aaaacd` 
    ) `JOIN_Article` 
    ON `JOIN_Article`.`aaaacd` =   `Tarclient`.`aoaacd`

    Une exception non gérée du type 'System.Data.OleDb.OleDbException' s'est produite dans System.Data.dll
    Informations supplémentaires*: Erreur de syntaxe dans la clause FROM.



    de même si je fais ceci :
    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
    SELECT *   
    FROM `Tarclient`   
    INNER JOIN    
    (
       SELECT `aaaacd` 
       FROM `Article` IN 'C:\\Mpb\\Bdd\\Article.mdb'  
    ) `JOIN_Article` 
    INNER JOIN    
       (
          SELECT `CodArt`
           FROM `StockMag` 
          IN 'C:\\Mpb\\Bdd\\StockMag.mdb'
        ) 
        `JOIN_StockMag`
    ON `JOIN_StockMag`.`CodArt` =   `Article`.`aaaacd`
    ON `JOIN_Article`.`aaaacd` =   `Tarclient`.`aoaacd`

  4. #4
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Je pense que la documentation apporte une réponse :
    Citation Envoyé par doc
    Remarks

    You can use IN to connect to only one external database at a time.

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 36
    Points : 34
    Points
    34
    Par défaut
    Merci

    et mince

    dommage, au boulot ils ont créer un fichier par table
    du coup pour faire des multi inner join c'est mort

  6. #6
    Membre éprouvé
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    956
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 956
    Points : 1 199
    Points
    1 199
    Par défaut
    Du temps d'access 97, il était possible de faire des liens entre les bases de données, je ne sais pas si c'est possible.
    Donc tu pouvais avoir une base consolidation avec des liens sur les autres bases et donc faire tes requêtes (attention aux chemins qui doivent être identiques).
    Je ne sais pas si c'est toujours possible et si c'est souhaitable.

    A+
    Soazig

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 36
    Points : 34
    Points
    34
    Par défaut
    soazig
    je me connais pas trop en access et en liens entre les bases de données

    en fait je n'ai pas le droit de toucher au fichier des bases de données

    Du coup pour contourner le problème (attention c'est très lourd) :

    dès que le programme détecte qu'il va créer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT `aaaacd` FROM `Article`   INNER JOIN    (SELECT `CodArt` FROM `StockMag` IN 'C:\\Mpb\\Bdd\\StockMag.mdb' WHERE 1 AND `StockMag`.`StkAS400`>10) `JOIN_StockMag` ON `JOIN_StockMag`.`CodArt` =   `Article`.`aaaacd` WHERE 1 AND `Article`.`aaaana`  LIKE '%aaa%'  AND 1"
    et qu'il va rajouté un inner

    je fait un Where à la place et le where il le crée en faisant :

    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
     using (OleDbDataReader reader = cmd.ExecuteReader())
                        {
                            WHERE = "";
                            while (reader.Read())
                            {
                                WHERE  += "'" + reader.GetString(0) + "',";
                            }
                            if (WHERE .Length > 0)
                            {
                                WHERE  = " `" + colonne_CodeArt + "` IN ( "
                                    +WHERE .Substring(0, WHERE .Length - 1)
                                    + ")";
                            }
                            else
                                WHERE  = "0";}
    qui donne : Where `aoaacd` IN ( '015121','026096','031920')

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

Discussions similaires

  1. soucis avec des requetes "INNER JOIN" Imbriquées
    Par Moutonstar dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 13/11/2008, 12h12
  2. [Conception] Erreur de syntaxe avec un champ de tableau
    Par lodan dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 21/09/2006, 11h45
  3. Problème de syntaxe avec des nombres
    Par baleiney dans le forum Langage
    Réponses: 7
    Dernier message: 09/07/2006, 10h48
  4. Erreur de syntaxe avec UPDATE
    Par tyarak dans le forum Requêtes
    Réponses: 3
    Dernier message: 01/02/2006, 01h18
  5. Erreur sur IIS avec des cripts ASP
    Par Alin dans le forum ASP
    Réponses: 7
    Dernier message: 22/06/2004, 14h15

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