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

PHP & Base de données Discussion :

Récupération de valeur MySQL (jointure) [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Inscrit en
    Mai 2009
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 2
    Par défaut Récupération de valeur MySQL (jointure)
    Bonjour,
    je suis actuellement sur un projet qui me demande de faire des jointure lors de mes SELECT mysql. Jusque la tout fonctionne j'arrive bien à récupérer le nombre de résultat souhaiter et à lier les deux tables. Par contre j'ai un problème dans ma boucle de récupération de donner pour spécifier la table dans laquelle je veux récupérer ma colonne.

    Exemple :
    MaTable_1 -> id, nom, prenom, type, FK_MaTable_2
    MaTable_2 -> id, blabla, toto, coucou, mikmik
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $query = "SELECT * FROM MaTable_1 INNER JOIN MaTable_2 ON MaTable_1.FK_MaTable_2 = MaTable_2.id";
    $result = mysql_query($query);
    while($row = mysql_fetch_object($result)) {
    $varOK = $row->nom; // OK ca marche c'est cool
    $varBUGGGGGGGGGGG = $row->MaTable_1.nom;
    // Impossible de trouver la syntaxe pour mentionner la table dans laquelle recuperer le champs, ce qui serait fort pratique lors de tables complexe, laisons multiple etc
    }
    Je suis bien d'accord que je pourrais faire des alias pour chaques champs en faisant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $query = "SELECT MaTable_2.id MonNouveauNom FROM MaTable_1 INNER JOIN MaTable_2 ON MaTable_1.FK_MaTable_2 = MaTable_2.id";
    $varBUGGGG = $row->MonNouveauNom; // Ca fonctionne mais pas pratique, je veux mon SELECT * wink.gif
    Quelqu'un connaitrait-il la syntaxe juste?

    Je vous remercie d'avance de vos interventions
    Bonne journée

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    mysql_fetch ne recupere que des champs, il n'a aucune idée des tables d'ou ils viennent.

    Si les deux tables ont une colonne "nom" tu es obligé de définir un alias ou de n'en indiquer qu'un dans le select.

    Ce problème ne se pose pas quand on a prit soin de prefixer le nom des champs avec le nom de la table (ie : mt1_nom)
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Candidat au Club
    Inscrit en
    Mai 2009
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 2
    Par défaut
    Parfait, au moin ça a le mérite d'être clair et rapide.
    Comme ca j'arrête de me triturer a chercher une réponse.

    En tout cas merci beaucoup et bonne soirée

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

Discussions similaires

  1. Mysql et php, récupération de valeurs combobox
    Par Gogochou dans le forum Langage
    Réponses: 5
    Dernier message: 15/06/2012, 15h45
  2. [MySQL] syntaxe variable lors d'une récupération de valeurs après mysql
    Par mussara dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 06/11/2006, 13h30
  3. [struts] [checkbox] récupération des valeurs cochées
    Par abourell dans le forum Struts 1
    Réponses: 16
    Dernier message: 10/06/2005, 20h58
  4. récupération de valeur de lien
    Par sex-sansbol dans le forum ASP
    Réponses: 3
    Dernier message: 07/06/2004, 10h43
  5. Récupération de valeurs d'un tableau
    Par leeloo076 dans le forum ASP
    Réponses: 12
    Dernier message: 25/03/2004, 10h59

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