php mysql 无限分类_PHP-mySql实现无限分类(递归、数组) | 学步园

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

1.mySql数据库表设计

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

ID

FID

NAME

1

0

一级分类

2

1

二级分类

3

2

三级分类

2.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 "";

/*foreach ($tree as $k=>$v){

$s='';

for ($i=1;$i<=$v['level'];$i++){

$s.='    ';

}

echo $s.$v['name']."
";

}*/

foreach ($tree as $arr=>$v) {

if($v['level']==4){

echo $v['name']."";

}

}

?>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值