我正在拉取目录的主列表并循环遍历,然后嵌套在循环中,我正在拉取一组与每个目录匹配的注释。
在下面的示例中,我如何不显示 dir 3 和 dir 4 列表?这些代表类别的徽标,如果结果为空,我不希望这些徽标出现。我阅读了 INNER JOIN ,但它似乎不符合这种需求,或者至少我不明白。
为了简化帖子,我删除了很多 html 表格和结构。这个想法是外部循环运行所有目录,但我无法真正检查内部(我知道)是否应该列出它。我将阅读下面由非常有用的海报发布的 LEFT JOIN 选项。
$sql_dir="SELECT dirid FROM lit_directories";
$result_dir=mysql_query($sql_dir);
while ($row_dir=mysql_fetch_assoc($result_dir)) {
edit here--> echo $row_dir['dirid'];
$sql_notes="SELECT notes, dirid FROM lit_notes WHERE dirid='".$row_dir['dirid']."'";
$result_notes=mysql_query($sql_notes);
while ($row_notes=mysql_fetch_assoc($result_notes)) {
echo $row_notes['notes'];
}
}
dirid notes
-----------------------
| dir 1 | notes 1
| | notes 2
| | notes 3
-----------------------
| dir 2 | notes 1
| | notes 2
-----------------------
| dir 3 | <---- I don't want these last 2 dir lists to show
| | since they are empty
-----------------------
| dir 4 | <----
| |
-----------------------