मुझे लगता है कि इन पंक्तियों के साथ कुछ करना चाहिए (अवांछित, आपकी आवश्यकताओं के अनुकूल होना चाहिए):
$q = mysql_query("SELECT id, parent_id, name FROM categories");
while ($r = mysql_fetch_row($q)) {
$names[$r[0]] = $r[2];
$children[$r[0]][] = $r[1];
}
function render_select($root=0, $level=-1) {
global $names, $children;
if ($root != 0)
echo '<option>' . strrep(' ', $level) . $names[$root] . '</option>';
foreach ($children[$root] as $child)
render_select($child, $level+1);
}
echo '<select>';
render_select();
echo '</select>';
ऐसा करने का एक और भी मजेदार तरीका SQL संग्रहीत कार्यविधियों का उपयोग करना है, लेकिन इस मामले में यह बहुत अधिक हो सकता है...