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 :

Problème sur un left join en version 4 mais pas en 5 !


Sujet :

Requêtes MySQL

  1. #1
    Membre confirmé Avatar de Christophe Charron
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2005
    Messages
    920
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2005
    Messages : 920
    Points : 606
    Points
    606
    Par défaut Problème sur un left join en version 4 mais pas en 5 !
    Bonsoir,
    En exécutant la requête suivante sur une base Mysql 4.1
    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
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    SELECT f1.action_cleunik, f1.choix_cleunik, f1.dateheuredebut, DATE_FORMAT( f1.dateheuredebut, GET_FORMAT( DATE, 'EUR' ) ) AS `datedebut` , DATE_FORMAT( f1.dateheuredebut, GET_FORMAT( TIME, 'ISO' ) ) AS `heuredebut` , f1.dateheurefin, DATE_FORMAT( f1.dateheurefin, GET_FORMAT( DATE, 'EUR' ) ) AS `datefin` , DATE_FORMAT( f1.dateheurefin, GET_FORMAT( TIME, 'ISO' ) ) AS `heurefin` , f1.dateheurecreation, f1.dateheuremodif, f1.description, f2.choix_valeur_texte_01 AS genre, f3.choix_valeur_texte_01 AS priorite, f4.choix_valeur_texte_01 AS statut, f5.act_cleunik, f5.int_cleunik, f5.portee AS 'portee', f6.raisonsoc AS `raisonsoc` , concat_ws( ' ', f7.prenom, f7.patronyme ) AS `qui_interlo`
    FROM _actions f1
    LEFT JOIN _graal f5
    USING ( action_cleunik )
    LEFT JOIN _acteurs f6
    USING ( act_cleunik )
    LEFT JOIN _act_interlo f7
    USING ( int_cleunik ) , _choix f2, _choix f3, _choix f4
    WHERE f2.choix_cleunik = f1.choix_cleunik
    AND f3.choix_cleunik = f1.priorite
    AND f4.choix_cleunik = f1.statut
    AND (
    f5.principal =2
    OR f5.principal IS NULL
    )
    AND (
    f1.description LIKE '%%'
    OR f1.description IS NULL
    )
    AND (
    (
    f1.dateheuredebut
    BETWEEN '19610123000000'
    AND '20610123235959'
    )
    OR (
    f1.dateheurefin
    BETWEEN '19610123000000'
    AND '20610123235959'
    )
    )
    ORDER BY f1.dateheuredebut DESC
    LIMIT 0 , 150
    j'ai erreur suivante :
    MySQL a réponduocumentation
    #1054 - Unknown column 'test_725.f6.int_cleunik' in 'on clause'
    Le même base importée en mysql 5 ne renvoie pas cette erreur.
    En l'occurrence, il est vrai que la colonne int_cleunik n'est pas présente dans la table aliasée f6, mais je comme je ne lui demande pas cette colonne !!! ...
    Est-ce une jointure spontanée qui voudrait se faire en Mysql 4 et pas en Mysql5 ??
    Tout ceci me laisse un peu perplexe et je vous saurai gré de m'éclairer s'il vous plaît.
    Cordialement,
    Christophe Charron

  2. #2
    Membre confirmé Avatar de Christophe Charron
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2005
    Messages
    920
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2005
    Messages : 920
    Points : 606
    Points
    606
    Par défaut
    complément d'information :
    si j'inverse l'ordre de la jointure
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    ...
    FROM _actions f1
    LEFT JOIN _graal f5
    USING ( action_cleunik )
    LEFT JOIN _act_interlo f7
    USING ( int_cleunik ) 
    LEFT JOIN _acteurs f6
    USING ( act_cleunik )
    , _choix f2, _choix f3, _choix f4...
    Ca ne plante plus en Mysql 4, ça à l'air de retourner des enregistrements mais je n'ai pas l'impression qu'ils y soient tous ... mais cela plante en Mysql 5 :
    Column 'act_cleunik' in from clause is ambiguous
    Cordialement,
    Christophe Charron

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

Discussions similaires

  1. tester concordance sur 2 LEFT JOIN
    Par charlene44 dans le forum Requêtes
    Réponses: 7
    Dernier message: 30/03/2011, 23h24
  2. Problème avec un LEFT JOIN/ RIGHT JOIN
    Par Moutonstar dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 25/11/2008, 14h03
  3. Interrogation sur le LEFT JOIN
    Par griese dans le forum Langage SQL
    Réponses: 4
    Dernier message: 05/01/2007, 15h10
  4. Problème sur un Inner Join
    Par Space Cowboy dans le forum Requêtes
    Réponses: 1
    Dernier message: 12/12/2006, 18h13
  5. Réponses: 3
    Dernier message: 13/11/2006, 17h06

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