PHP-mySql实现无限分类(递归、数组)

以下代码如有错误,请在评论中指出,谢谢!

1.mySql数据库表设计

 有3列 分别是ID  (主键、自动增长)  、FID  (int)、  NAME(分类名称),FID 是保存上一级分类的ID

IDFIDNAME
10一级分类
21二级分类
32三级分类

 

2.PHP打印出代码

<?php
$conn=mysql_connect('127.0.0.1','root','123');
mysql_select_db('test');
mysql_query('set names utf8',$conn); //链接数据库

header("content-type:text/html;charset=utf-8"); //内容类型

function getName($fid,&$tree,$level=0){ //$fid FID号,& $tree可以改变外部数组,保存SQL数据,$level分类级别,默认为1级
       $level++;
       $query=mysql_query("select * from test where fid=".$fid);
       while ($row=mysql_fetch_array($query)){
           $tree[$row['id']]['id']=$row['id'];
//把表保存到二维数组$tree
           $tree[$row['id']]['name']=$row['name'];
           $tree[$row['id']]['fid']=$row['fid'];
           $tree[$row['id']]['level']=$level;
          $num=mysql_query("select * from test where fid=".$row['id']);
//读取下一级别是否存在
          if(mysql_num_rows($num)>0){
               getName($row['id'],$tree,$level);//递归调用自己
          } 
      }
}

//返回二维数组

function tree($parent_id=0){
    $tree=array();
    getName($parent_id,$tree);
    return $tree;
}

//打印数组

$tree=tree();

print_r($tree);
echo "</br>";
/*foreach ($tree as $k=>$v){
 $s='';
 for ($i=1;$i<=$v['level'];$i++){
         $s.='&nbsp;&nbsp;&nbsp;&nbsp;';
 }
echo $s.$v['name']."<br />";
}*/

foreach ($tree as $arr=>$v) {
      if($v['level']==4){
           echo $v['name']."</br>";
      }
}
?>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值