无限级分类--1(商品分类)

这篇博客探讨了电商领域商品分类的无限级分类方法,重点在于如何通过递归调用实现。文章指出,此类分类需要在数据库设计时考虑,确保子类别包含父类别的ID,顶级类别ID为0。内容包括对表结构的描述和代码实现,展示了一个无限级分类查询的结果格式。
摘要由CSDN通过智能技术生成

无限级分类多用于商品的分类

其原理就是调用函数体本身,通过传递的参数不同,则查出的数据不同

无限级分类对表的设计有着要求,子类中必须有父类的id,如果是顶级分类id则父级id(parent_id)的值为0

表字段:

 cat_id(自增id)     cat_name(名称)    parent_id(父类id)

代码实现:


    //无限级分类
    public function always_category($path=0)
    {
        $data = Db::table('category')->field(['cat_id','cat_name','parent_id'])->where(['parent_id'=>$path])->select();
        foreach($data as $key=>$val)
        {
            $son = $this->always_category($val['cat_id']);
            if(!empty($son))
            {
                $data[$key]['son'] = $son;
            }
        }
        return $data;
    }

查出的结果格式如下:

 Array
(
    [0] => Array
        (
            [cat_id] => 28
            [cat_name] => 手机、数码
            [parent_id] => 0
            [son] => Array
                (
                    [0] => Array
                        (
                            [cat_id] => 29
                            [cat_name] => 手机通讯
                            [parent_id] => 28
                            [son] => Array
                                (
                                    [0] => Array
  
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值