我正在尝试从数据库中获取我的类别及其子类别<optgroup>
和<option>
标签,我希望父母成为<optgroup>
标签,但我无法遍历所有级别,我只能达到第 2 级,而且我不能走得太远!
这是我到目前为止得到的:
$con = mysql_connect($dbHost, $dbUsername, $dbPassword);
if (!$con) {
echo "Cannot connect to the database: " . mysql_error();
exit;
}
$db_selected = mysql_select_db($dbName, $con);
if (!$db_selected) {
echo "Can\'t use $dbName : " . mysql_error();
exit;
}
$query = "SELECT * FROM categories";
$result = mysql_query($query);
$pidHolder = null; // To take the current parent pid in the loop
$optOpen = false; // Check that optgroup tag is opened
while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) {
if ($line['parent_id'] == 0 && $line['cat_id'] == 0)
continue;
if ($line['parent_id'] == 0) {
if ($optOpen) {
echo '</optgroup>';
$optOpen = false;
}
echo "<optgroup value=" . $line['cat_name'] . "\" label=\"" . $line['cat_name'] . "\">";
$pidHolder = $line['cat_id'];
$optOpen = true;
continue;
} else if (isset($pidHolder) && $pidHolder == $line['parent_id']) {
echo '<option value="' . $line['cat_id'] . '">' . $line['cat_name'] . '</option>\n';
continue;
}
}
mysql_close();
我的代码有什么问题?我需要什么来遍历其余的孩子?