php+mysql网站无限级栏目分类-递归获取树形结构函数

本文介绍了一种使用PHP和MySQL实现无限级栏目结构的方法,通过递归函数获取所有子分类并将其组织成树形结构,同时讨论了缓存策略以提高查询效率。

如果网站采用了无限级栏目结构,我们可以将网站所有栏目获取出来组成一个树形结构。
数据库结构:


函数代码:

//获得指定文章分类的子分类组成的树形结构
 function cateTree($pid=0,$level=0){
    $cate=M('cate');
    $array=array();
    $tmp=$cate->where("pid='%d'",$pid)->select();
    if(is_array($tmp)){
        foreach($tmp as $v){
            $v['level']=$level;
            $array[count($array)]=$v;
            $sub=cateTree($v['id'],$level+1);
            if(is_array($sub))$array=array_merge($array,$sub);
        }
    }
    return $array;
 }

 

复制代码

效果[print_r(cateTree(0))]:

Array
(
  [0] => Array
  (
    [id] => 1
    [catename] => 测试分类
    [pid] => 0
    [status] => 0
    [level] => 0
  )

  [1] => Array
  (
    [id] => 5
    [catename] => 二级分类
    [pid] => 1
    [status] => 0
    [level] => 1
  )

  [2] => Array
  (
    [id] => 7
    [catename] => 三级分类2
    [pid] => 5
    [status] => 0
    [level] => 2
  )

  [3] => Array
  (
    [id] => 2
    [catename] => 测试分类
    [pid] => 0
    [status] => 0
    [level] => 0
  )

  [4] => Array
  (
    [id] => 4
    [catename] => 又来测试
    [pid] => 0
    [status] => 0
    [level] => 0
  )

  [5] => Array
  (
    [id] => 6
    [catename] => 二级分类二
    [pid] => 4
    [status] => 0
    [level] => 1
  )

  [6] => Array
  (
    [id] => 8
    [catename] => 三级测试
    [pid] => 6
    [status] => 0
    [level] => 2
  )
)

 


其中level表示其层级。
格式化输出效果:

 

方法仅供参考,有人说递归查询效率不好,其实在实际应用过程中我们可以把查询出来的内容放入缓存,然后修改栏目信息的时候更新缓存,不需要每次都来查询数据库。

转载于:https://www.cnblogs.com/dragondean/p/php-mysql-catetree.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值