我怎样才能避免在 PHP 的 While 循环中使用 MySQL 查询


How could I avoid using a MySQL query in a While loop in PHP

我有一个while循环,输出一个类列表。在类数据库中,教师姓名由用户数据库中的教师 ID 确定。

这是我的数据库结构。

Classes Database
-----------------------------
ID       CLASS              TEACHER
1        product design     3
User Database
-----------------------------
ID       NAME
3        John Doe

因此,在列出我的类时,我需要它将"3"转换为"John Doe"。

这是我当前的代码:

<?php 
  $classdetails = mysql_query("SELECT * FROM class");
  while($class = mysql_fetch_array($classdetails)) {
    $marklist_class = $class['class'];
    $marklist_teacher = $class['teacher']; //This is a userid                                   
    //------Somewhere here i need to get the userid and look it up in the user database
    if($marklist_class=="") {
    } else {
      echo $marklist_class . ' ' . $marklist_teacher;}
    }
  }
?>

我知道只是在那里放置另一个 mysql 查询会降低性能并且不建议这样做,那么我将如何在不将查询添加到 while 循环的情况下查找每一行的用户数据库。

谢谢。

您可以使用联接查询一次获取所需的所有信息。然后在您的应用程序中,您可以对其进行排序并相应地显示。例如

SELECT Classes.class, Users.Name
FROM Classes JOIN Users on Classes.Teacher = Users.ID

你想在mysql中使用JOIN。

SELECT * FROM class c JOIN user u ON u.ID = c.TEACHER

您可以在初始查询中使用 JOIN。

Select c.id, c.class, c.teacher, u.name from class c join user u on u.id = c.teacher

这将在一个查询中返回 Class 中的所有列,以及 User 中匹配的教师姓名列。