私は階層検出スクリプトをコーディングしようとしていますが、私は既にスクリプトを書いていますが、4レベルしか下げることはできません。無限のレベルで動作する数行にこれを凝縮する方法はありますか?より効率的な階層システム
このスクリプトは基本的に同じコードのコピーであり、categories
ための貼り付け4回
<?php
function listCategories($name, $disable_status = 0, $show_nums = 0) {
echo "<select name='".$name."'>";
$result = mysql_query("SELECT * FROM categories") or die(mysql_error());
while($row = mysql_fetch_array($result)) {
if($row['parent_id']==0) {
$result2 = mysql_query("SELECT * FROM categories WHERE parent_id=".$row['id']) or die(mysql_error());
echo "<option value='".$row['id']."'";
if($disable_status==1&&isParent($row['id'])){
echo " disabled='disabled'";
}
echo ">".$row['name']."</option>";
while($row2 = mysql_fetch_array($result2)) {
$result3 = mysql_query("SELECT * FROM categories WHERE parent_id=".$row2['id']) or die(mysql_error());
echo "<option value='".$row2['id']."'";
if($disable_status==1&&isParent($row2['id'])){
echo " disabled='disabled'";
}
echo ">- ".$row2['name']."</option>";
while($row3 = mysql_fetch_array($result3)) {
$result4 = mysql_query("SELECT * FROM categories WHERE parent_id=".$row3['id']) or die(mysql_error());
echo "<option value='".$row3['id']."'";
if($disable_status==1&&isParent($row3['id'])){
echo " disabled='disabled'";
}
echo ">-- ".$row3['name']."</option>";
while($row4 = mysql_fetch_array($result4)) {
echo "<option value='".$row4['id']."'>[".$row4['id']."] --- ".$row4['name']."</option>";
}
}
}
}
}
echo "</select>";
}
function isParent($cat_ID) {
$result = mysql_query("SELECT * FROM categories WHERE parent_id=".$cat_ID) or die(mysql_error());
if(mysql_num_rows($result)==0) {
return FALSE;
} else {
return TRUE;
}
}
私のテーブル構造が
id, name, parent_id
あるカテゴリに親がない場合は、parent_id
になります0
それ以外の場合は、親のカテゴリのid
になります。
すべてのご協力をいただきありがとうございます。
この問題を解決するために再帰を使用できます。私はすぐに詳細を説明する時間がありません - うまくいけば誰かがすぐになります:) – Treffynnon
OMG my eyeeeeees !!! TT – CAFxX
この回答はあなたにとって単純すぎるかもしれません。http://stackoverflow.com/questions/5291054/hierarchical-sql-problem/5291159#5291159 –