求修改个无限分类递归函数

amu1433 2013-03-19 01:41:03


// ========== findFather函数 START ==========
// 功能:无限级分类之找出父层的相关数据
// 参数:$classID,当前子层的编号
// $type,0找自己 1找父亲 2找祖先 3找家谱
// 字段:classID主键,自生成 classFID父编号
// className分类名称 classCount分类统计
function findFather($classID,$type)
{
global $flist,$forefather;
define("_STR_CUT", " -> ");
$sql = 'select * from mar_menu where id = "'.$classID.'"';
$res1 = _query($sql);
$row=_fetch_array($res1);
if ($row)
{
//取值
$classFID = $row['ppid'];
$classID = $row['id'];
$className = $row['m_title'];

//若找到祖先,即classFID为0,则将函数状态设为0
if ($classFID == '0') $type='0';
}
if ($type == '1') //找父亲
{
$type = '0'; //第二次开始函数状态为0,即循环2次
findFather($classFID,$type);
$flist = $flist . _STR_CUT . $className; //生成家谱
}
else if ($classFID != '0' AND $type == '2') //找祖先,状态type为2,祖先classFID不为0未找到
{
findFather($classFID,$type);
$flist = $flist . _STR_CUT . $className; //生成家谱
}
else if ($type == '3')
{
findFather($classFID,$type);
$flist = $flist . _STR_CUT . $className; //生成家谱
}
else if ($type == '0')
{
$forefather = $className;
}

$result = $forefather . $flist;
return $result;

}



求修改下 用循环 直接查找所有的父栏目
这儿函数 只能到3层节点 能否修改成无限的.我的数据有可能超过4层节点



















...全文
170 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
ustb 2013-03-19
  • 打赏
  • 举报
回复

$conn = mysql_connect("localhost", "test", "test");
mysql_select_db("test", $conn);
mysql_set_charset("utf8", $conn);

$res = mysql_query("select * from region");

$data = array();
while ($row = mysql_fetch_assoc($res))
{
    $data[] = $row;
}

print_r($data);

function findParents($class_id)
{
    global $data;
    static $_tree;
    foreach ($data as $key => $val)
    {

        if ($val['classID'] == $class_id)
        {
            $pid = $val['classFID'];
            $_tree[] = $val;
            if ($pid != 0)
            {
                findParents($pid);
            }
        }
    }
    return $_tree;
}

$rs = findParents(4);
krsort($rs);
print_r($rs);
scoutlin 2013-03-19
  • 打赏
  • 举报
回复
$f=array(); function findFather($classID,$type){ global $db; global $f; for($t=0;$t<=$type;$t++){ $res=$db->query("select * from mar_menu where classID=$classID"); findFather($res[0]['classFID'],$type-1); $f[]=$res[0]['className']; return ; } } findFather(4,1); echo implode("->",$f);
amu1433 2013-03-19
  • 打赏
  • 举报
回复
等待 牛人...顶贴!
amu1433 2013-03-19
  • 打赏
  • 举报
回复
$classFID = $row['ppid']; $classID = $row['id']; $className = $row['m_title']; 应该是 $classFID = $row['classFID']; $classID = $row['classID']; $className = $row['className']; 这个写错了 不好意思

21,886

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧