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 :

Joindre 3 tables


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Webmaster
    Inscrit en
    Août 2006
    Messages
    71
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Août 2006
    Messages : 71
    Par défaut Joindre 3 tables
    Bonjours,
    j'ai trois table a relier ensemble.

    - la première représente toutes les villes de France avec un ID ( table maps_ville)
    - la seconde représente ma table ou je vais stoker les photographies. ( table photo)
    - La troisième est la table qui doit: relier a la 1ere et 2ème (table vente)

    j'ai fait ce code mais cela n'affiche pas le nom des villes sur ma page en php
    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
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
     
    <?php include('connection.php'); ?>
     
    <?php
     
    // appeler les valeurs pour afficher les photos //
    // ID    PHOTO    VILLE    PRIX  //   
    ////////////////////////////////////////////////////
     
    // CONNECTION A MySQL //
    $connexion = mysql_connect($hote, $utilisateur, $mdp) or die("erreur de connexion a la base de donnees"); 
     
    // CONNECTION A LA BDD //
    $choix_base = mysql_select_db($data_base, $connexion)  or die("erreur de connexion a la base de donnees");
     
    // rechercher les valeurs de la table vente //
    $req = "SELECT id, vente_ville, vente_photo, prix, date
    FROM vente
    RIGHT JOIN maps_ville ON id_ville = vente_ville
    RIGHT JOIN photo ON id_photo = vente_photo
    LIMIT 0,6";
    $result=mysql_query($req);
     
    // On fait une boucle pour lister tout ce que contient la table :
    while($val = mysql_fetch_array($result))
    {
     
    // MISE EN PLACE DES PETITES IMAGES AVEC PRIX ET VILLE + LIEN VERS ANNONCES (en html)
    echo $val['date']; // affiche les dernier inscrit
    ?>
    <div style="width:250px; height:250px; background-color:#FFFF99">
    <img src="update/<?php $id_photo ?>" /><br />
    Annonce N° <?php  echo $val['id']; ?><br />
    <?php echo $val['vente_ville']; ?><br />
    <?php echo $val['prix']; ?>
    </div>
     
    <?php
    }
     
    // Déconnexion de MySQL
    mysql_close($connexion); 
    ?>

  2. #2
    Inactif  
    Homme Profil pro
    Inscrit en
    Septembre 2003
    Messages
    570
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Septembre 2003
    Messages : 570
    Par défaut
    est ce que vente_ville que tu affiche ici
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <?php echo $val['vente_ville']; ?><br />
    est le noms du champs de la table maps_ville qui correspond au nom d'une ville?
    - si OUI ta jointure et incorrecte, refait là en utilisant les cles primaires des table maps_ville et photo et les cles etrangers de la table vente
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    //remplacer
    $req = "SELECT id, vente_ville, vente_photo, prix, date
    FROM vente
    RIGHT JOIN maps_ville ON id_ville = vente_ville
    RIGHT JOIN photo ON id_photo = vente_photo
    LIMIT 0,6";
    //par
    //remplacer
    $req = "SELECT id, vente_ville, vente_photo, prix, date
    FROM vente
    RIGHT JOIN maps_ville ON maps_ville.id_ville = vente.id_ville
    RIGHT JOIN photo ON maps_ville.id_photo = photo.id_photo
    LIMIT 0,6";
    si ces clés primaire n'ont pas de correspondant dans la table vente il y a une erreur de modélisation, montrer les champs de tes tables pour s'en assurer.
    - si NON alors tu affiche le mauvais champs

  3. #3
    Membre confirmé
    Homme Profil pro
    Webmaster
    Inscrit en
    Août 2006
    Messages
    71
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Août 2006
    Messages : 71
    Par défaut
    tout a fait le code

    <?php echo $val['vente_ville']; ?><br />
    affiche le mon de la ville.

    ce que tu m'a donnée cela me donne l'erreur
    Warning: mysql_fetch_array() expects parameter 1 to be resource, boolean given in C:\Program Files\wamp\www\vendre.fr\affiche_annonce_index.php on line 24
    je fait voir mes trois tables
    la table maps_ville
    - id_ville
    - id_departement
    - nom
    - cp
    - latitude
    - longitude

    la table photo
    - id_photo
    - photo1 (c'est cette photo a utilisé sur la page)
    - photo2
    .....

    la table vente
    - id
    - vente_ville (a lier avec maps_ville pour afficher le mon des villes)
    - vente_photo (a lier avec photo pour afficher la photo1)
    - prix
    - date
    (les autres champs ne sont pas nécessaire pour afficher sur la page)

  4. #4
    Inactif  
    Homme Profil pro
    Inscrit en
    Septembre 2003
    Messages
    570
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Septembre 2003
    Messages : 570
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    la table vente
    - id 
    - vente_ville (doit correspondre au champs id_ville de la table maps_ville) 
    - vente_photo (doit correspondre au champs id_photo de la table photo) 
    - prix 
    - date
    alors tu peut faire :
    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
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
     
    <?php include('connection.php'); ?>
     
    <?php
     
    // appeler les valeurs pour afficher les photos //
    // ID    PHOTO    VILLE    PRIX  //   
    ////////////////////////////////////////////////////
     
    // CONNECTION A MySQL //
    $connexion = mysql_connect($hote, $utilisateur, $mdp) or die("erreur de connexion a la base de donnees"); 
     
    // CONNECTION A LA BDD //
    $choix_base = mysql_select_db($data_base, $connexion)  or die("erreur de connexion a la base de donnees");
     
    // rechercher les valeurs de la table vente //
    $req = "SELECT id, maps_ville.nom AS maville, photo.photo1 as maphoto, prix, date
    FROM vente
    INNER JOIN maps_ville ON maps_ville .id_ville = vente.vente_ville
    INNER JOIN photo ON photo.id_photo = vente.vente_photo
    LIMIT 0,6";
    $result=mysql_query($req);
     
    // On fait une boucle pour lister tout ce que contient la table :
    while($val = mysql_fetch_array($result))
    {
     
    // MISE EN PLACE DES PETITES IMAGES AVEC PRIX ET VILLE + LIEN VERS ANNONCES (en html)
    echo $val['date']; // affiche les dernier inscrit
    ?>
    <div style="width:250px; height:250px; background-color:#FFFF99">
    <img src="update/<?php echo $val['maphoto'];?>" /><br />
    Annonce N° <?php  echo $val['id']; ?><br />
    <?php echo $val['maville']; ?><br />
    <?php echo $val['prix']; ?>
    </div>
     
    <?php
    }
     
    // Déconnexion de MySQL
    mysql_close($connexion); 
    ?>

Discussions similaires

  1. Réponses: 3
    Dernier message: 24/09/2007, 11h54
  2. joindre deux tables créées par requêtes
    Par bernard6 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 04/04/2007, 11h27
  3. [D7-ACCESS-ADO] Joindre deux tables
    Par dleu dans le forum Bases de données
    Réponses: 6
    Dernier message: 25/11/2006, 14h16
  4. joindre 2 tables d'apres une categorie
    Par freija dans le forum Langage SQL
    Réponses: 1
    Dernier message: 02/08/2006, 20h08
  5. Joindre plusieurs tables pour en former qu'une seule.
    Par timeout dans le forum Requêtes
    Réponses: 7
    Dernier message: 19/09/2005, 09h18

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