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

Requêtes MySQL Discussion :

Column 'c2' in from clause is ambiguous


Sujet :

Requêtes MySQL

  1. #1
    Membre régulier
    Profil pro
    INGENIEUR DE RECHERCHE
    Inscrit en
    Février 2003
    Messages
    74
    Détails du profil
    Informations personnelles :
    Âge : 57
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : INGENIEUR DE RECHERCHE

    Informations forums :
    Inscription : Février 2003
    Messages : 74
    Points : 87
    Points
    87
    Par défaut Column 'c2' in from clause is ambiguous
    Bonjour,

    L'erreur 1052 : Column 'c2' in from clause is ambiguous s'affiche.

    MySQL 5.0.41(je viens d'y passer)
    Linux RHEL4 x86_64

    requete :
    SELECT t1.*
    FROM
    t1
    INNER JOIN t2 USING(c1)
    INNER JOIN t3 USING(c2)
    INNER JOIN t4 USING(c2)

    Je précise que t1 possède aussi un champs C2 et que si j'enlève t1 çà marche et que la requête fonctionne en version 4.1.

    Merci d'avance car là je bloque. Je me vois pas repasser toutes les requêtes pour mettre du 'ON' qui lui fonctionne.
    Spiale

  2. #2
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut
    Bonjour,

    Effectivement, MySQL se retrouve avec 2 colonnes c2 (une dans T1 et une dans T2) pour faire la jointure avec T3... Il est un peu perdu.
    Le mieux, je pense, est d'utiliser la syntaxe suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT t1.*
    FROM t1
    INNER JOIN t2 on t1.c1 = t2.c1
    INNER JOIN t3 on t2.c2 = t3.c2
    INNER JOIN t4 on t4.c2 = t3.c2
    Comme ça, au moins, les choses sont clairement précisées

    ced
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  3. #3
    Membre régulier
    Profil pro
    INGENIEUR DE RECHERCHE
    Inscrit en
    Février 2003
    Messages
    74
    Détails du profil
    Informations personnelles :
    Âge : 57
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : INGENIEUR DE RECHERCHE

    Informations forums :
    Inscription : Février 2003
    Messages : 74
    Points : 87
    Points
    87
    Par défaut
    Merci,
    c'est bien que je pensais. De plus une autre réponse sur le forum de MySQL le confirme :

    Bonjour,

    Si je comprends bien le manuel, il semble que ce comportement soit voulu car
    il correspond au fonctionnement défini dans le standard SQL:2003.

    Par conséquent, il vous sera necessaire de réécrire vos requêtes pour MySQL 5.0

    Voir la section "Join Processing Changes in MySQL 5.0.12" [dev.mysql.com]

    Cordialement,

    Thomas CORBIERE
    Spiale

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 28/12/2010, 21h00
  2. Can't specify target in FROM clause
    Par Linio dans le forum Requêtes
    Réponses: 5
    Dernier message: 10/12/2010, 15h00
  3. Réponses: 3
    Dernier message: 07/03/2008, 14h31
  4. [MySQL] unknown column "motClef" in WHERE clause
    Par JackBeauregard dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 11/09/2007, 17h15
  5. Unknown column 'xx' in 'where clause'
    Par SaeZ dans le forum Requêtes
    Réponses: 3
    Dernier message: 30/05/2006, 17h25

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