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 :

Jointures entre 3 tables


Sujet :

PHP & Base de données

  1. #1
    Candidat au Club
    Homme Profil pro
    Lycéen
    Inscrit en
    Mai 2014
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Niger

    Informations professionnelles :
    Activité : Lycéen
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2014
    Messages : 2
    Points : 2
    Points
    2
    Par défaut Jointures entre 3 tables
    Bonsoir, je suis sur un petit projet dans lequel j'ai besoins de faire des jointures entre 3 tables.

    Le but est de faire en sorte que dans la page d'accueil, on puisse afficher les articles des utilisateurs, avec lesquels l'utilisateur actif est ami.

    Dans ma base de donnée j'ai les tables suivantes : users, amis, et posts.

    La table users contient les colonnes suivantes : id, username, nom, prenom, email ...

    La table amis contient : id_requete, id_exp, id_dest, date_invitation, date_confirmation, date_vue, et active (de valeurs 1 s'ils sont amis, 0 si la demande est en attente).

    Quant à la table post : id, msg, post_date, id_user.

    J'ai essayé la requête suivant, mais elle ne fonctionne que quand c'est l'utilisateur actif a envoyé la demande d'amitié.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <?php
    include('db.php');
    $act_user_id = $_SESSION['userid'];
    $sql_cat = "SELECT * FROM posts AS p, users AS u, amis AS a WHERE u.id = p.id_author AND a.id_exp = '$act_user_id' AND a.id_dest = u.id AND a.active = '1' ORDER BY post_date DESC LIMIT 0, 50";
    $res_cat = mysql_query($sql_cat);
    // Traitement et affichage des données
    while ( $categorie = mysql_fetch_assoc($res_cat) ) {
    $affich_categorie = $categorie['msg'];
    ?>

  2. #2
    Membre averti
    Avatar de crozet.magenta
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2012
    Messages
    208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Var (Provence Alpes Côte d'Azur)

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

    Informations forums :
    Inscription : Juin 2012
    Messages : 208
    Points : 374
    Points
    374
    Par défaut
    Salut
    Tu fais une recherche uniquement si l'utilisateur actif est dans la colonne exp donc ton résultat est cohérent mais ne retourne pas ce que tu veux. Tu dois rajouter dest dans ta requête. Essaye avec ça :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <?php
    include('db.php');
    $act_user_id = $_SESSION['userid'];
    $sql_cat = "SELECT * FROM posts AS p, users AS u, amis AS a WHERE u.id = p.id_author AND (a.id_exp = '$act_user_id' OR a.id_dest = '$act_user_id')AND a.id_dest = u.id AND a.active = '1' ORDER BY post_date DESC LIMIT 0, 50";
    $res_cat = mysql_query($sql_cat);
    // Traitement et affichage des données
    while ( $categorie = mysql_fetch_assoc($res_cat) ) {
    $affich_categorie = $categorie['msg'];
    ?>

    Au passage tu ne devrais plus utiliser les fonctions mysql_xxx et utiliser mysqli_xxx ou pdo en remplacement
    n'oubliez pas de voter si le message vous a aidé


  3. #3
    Candidat au Club
    Homme Profil pro
    Lycéen
    Inscrit en
    Mai 2014
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Niger

    Informations professionnelles :
    Activité : Lycéen
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2014
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Merci pour la réponse
    J'ai essayé avec la correction que tu as apportée à la requête que j'ai effectuée, toujours le même résultat.
    Lorsque je me rend sur la page de l'utilisateur qui a reçu la demande à ma liste d'amis, le flux ne contient que les entrées des utilisateurs que lui a ajouté. J'sais pas si tu me suis avec ce long texte

  4. #4
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Chouette un problème SQL.

    D'abord, il faut mieux compartimenter tes problèmes, pour les régler un par un.

    Teste ton SQL sur ton interface graphique de db.
    Ca ne sert à rien de passer par le PHP pour caler ton SQL.

    Evite aussi de mélanger les filtres et les jointures, ça ne t'aide pas à y voir clair.

    Ici, ton filtre, c'est un utilisateur ? alors on part de la table users que l'on va filtrer, et tes jointures... ben je te fais cette proposition, mais il peut encore y avoir des erreurs...
    Teste et raconte-nous.

    Cette requête te donnerait tous les posts des amis de 14, mais sans les posts de 14...

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT p.id_user,u.username,p.msg,a.id_dest AS amis_de /*j'ai mis un champ de chaque table pour que tu puisses vérifier*/
    FROM
    users u /*Tu pars des utilisateurs*/
    INNER JOIN amis a ON u.id=a.id_dest AND a.active=1 /*jointure 1 tu veux les amis de ton utilisateur*/
    INNER JOIN posts p ON a.id_exp=p.id_user/*jointure 2 tu veux les posts de CES amis*/
    WHERE u.id =14 /*Tu filtres ta table de départ => ici id de l'utilisateur, j'ai mis 14 au pif*/
    ORDER BY p.post_date DESC LIMIT 0, 50;
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

Discussions similaires

  1. PROBLEME DE JOINTURE ENTRE DEUX TABLE
    Par DarkMax dans le forum Langage SQL
    Réponses: 13
    Dernier message: 13/01/2005, 15h11
  2. Jointure entre 3 tables
    Par zigune dans le forum Langage SQL
    Réponses: 9
    Dernier message: 15/11/2004, 16h04
  3. Jointure entre deux tables et résultat
    Par Asdorve dans le forum Langage SQL
    Réponses: 2
    Dernier message: 02/06/2004, 14h50
  4. [jointure]requete possible de double jointure entre 2 tables
    Par akira_le_gaucher dans le forum Langage SQL
    Réponses: 4
    Dernier message: 11/05/2004, 15h03
  5. Jointure entre 2 tables et OR
    Par PyRoFlo dans le forum Requêtes
    Réponses: 2
    Dernier message: 02/02/2004, 18h42

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