sql >> Database >  >> RDS >> Mysql

Gebruikers-ID omzetten in naam (aparte tabellen) in PHP

Dus wat je nodig hebt is een paar JOIN s (impliciet INNER JOIN ) tegen users , een om mee te doen aan de volger en een om mee te doen aan de gevolgde.

SELECT 
  /* Rather than SELECT * you need to be specific about the columns, and
     give them aliases like followed_name since you have 2 tables with the same
     column names in the query */
  ufollower.id AS follower_id,
  ufollower.username AS follower_name,
  ufollowed.id AS followed_id,
  ufollowed.username AS followed_name
FROM
  /* JOIN twice against users, once to get the follower and once to get the followed */
  user_follow 
  /* users aliased as ufollower to get the follower details */
  JOIN users ufollower ON ufollower.id = user_follow.follower
  /* users aliased as ufollowed to get the followed details */
  JOIN users ufollowed ON ufollowed.id = user_follow.followed
WHERE
  user_follow.follower = $p_id

In uw lus zijn de namen beschikbaar in follower_name, followed_name .

while($apple = mysql_fetch_array($following)){
   // Be sure to wrap the name in htmlspecialchars() to encode characters that could break html.
   // This has the followed id in the href and the followed name in the link text...
   echo '<a href="'.$apple['followed_id'].'">+'.htmlspecialchars($apple['followed_name']) .'</a> ';
}


  1. Webinar:nieuwe functies in PostgreSQL 11 [vervolgen]

  2. Hoe om te gaan met De MySQL-server wordt uitgevoerd met de optie --secure-file-priv, zodat deze deze instructie niet op een Mac kan uitvoeren

  3. MySQL-openingstijden

  4. MySQL - Combineren van INSERT, VALUES en SELECT?