首页 > 编程知识 正文

php无限分类例子,php无限分类的原理

时间:2023-12-27 22:26:34 阅读:324516 作者:OFCA

本文目录一览:

php 无限分类

可以在表A中增加一个字段,该字段关联表B的SID,或者可以新建一张关联表C (ID,NEWSID,SID) 起到关联作用

select * from b2b_news as a,b2b_news_sort as b where a.sid= b.sid

是关联查询吗 ,如果有其他条件的话,在后面加and吧

php 几种常用的递归 无限极分类

 /**

     * 递归实现无限极分类

     * @param $array 分类数据

     * @param $pid 父ID

     * @param $level 分类级别

     * @return $list 分好类的数组 直接遍历即可 $level可以用来遍历缩进

     */

    function getTree($array, $pid =0, $level = 0){

        //声明静态数组,避免递归调用时,多次声明导致数组覆盖

        static $list = [];        foreach ($array as $key = $value){            //第一次遍历,找到父节点为根节点的节点 也就是pid=0的节点

            if ($value['pid'] == $pid){                //父节点为根节点的节点,级别为0,也就是第一级

                $value['level'] = $level;                //把数组放到list中

                $list[] = $value;                //把这个节点从数组中移除,减少后续递归消耗

                unset($array[$key]);                //开始递归,查找父ID为该节点ID的节点,级别则为原级别+1

                getTree($array, $value['id'], $level+1);

            }

        }

PHP MYSQL 请教 2个字段能无限分类吗?

没懂你的CID,和scid  是什么。

无限分类是无限的树形结构么?

根据无限树形结构说一下。一般情况下 是用递归调用来处理的。字段中  用id 和parentid 两个字段。 假设有一个函数 fetch是取mysql 数据的。简单写一个函数

function getdata($parentid){

$tree=fetch("parentid = {$parentid}");

 foreach($tree as $k= $v){

$tree[$k]['children']=getdata($v['id']);

}

return $tree;

}

调用$tree=getdata(0);

$tree  就是树形的。

当然 如果有用框架估计更简单点。比如laravel 。定义一个$tree的模型,表中有id,和parentid两字段。模型中新增两个函数

public function childrentree()

  {

      return $this-hasMany(get_class($this), 'parentid', 'id');

  }

  public function children()

  {

      return $this-childrentree();

  }

然后使用

tree::with(["children"])-where('parentid', 0)-get();  就可以获取树形菜单

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。