如何根据父类id关联获取所以最低级类目

需求:比如说有一个N多级类目,如下截图,那么我们需要获取到没有子类的所有类目id。

 如何根据父类id关联获取所以最低级类目

结构表如下:

 如何根据父类id关联获取所以最低级类目

分析:

:最开始我第一想法是,这个需要写一个递归,无限极获取下级,直到没有下级表示,当前即为最低类目。

:然后写着,写着,发现这样不是很明智,每一个类目下,都要去递归,这样消耗太大了,应该不合理。

:后来一想,既然每个类目都有父类(一级类,的父id是0);就好比,每个人都有一个父亲(第一个父亲,的父亲是谁^-^),但是不是每一个都有儿子;那么即可知道这个没有儿子的,就是我们要的,最低类。

:所以,直接将所有类目记录的 父类id 和 类目id 进行 差集处理,最后得到的,就是最低类目id。

代码如下:

// 获取所以最低级类目
    public function getCategoryBasementLanguageLogicAmend($input)
    {
        $cate = ApCategories::where('site_code', 'MY')->where('platform', $input['platform'])->get(['category_id', 'parent_id', 'category_name_chinese', 'category_name'])->toArray();
        $id_arr = array_column($cate, 'category_id');
        $pid_arr = array_column($cate, 'parent_id');
        $ids = array_diff($id_arr, $pid_arr);
        $cate_list = ApCategories::where('site_code', 'MY')->where('platform', $input['platform'])->whereIn('category_id', $ids)->select('category_id', 'category_name_chinese', 'category_name', 'level')->get()->toArray();
        foreach($cate_list as $key => &$value){
            if($value['category_name_chinese']){
                $value['category_name'] = $value['category_name_chinese'] . '(' . $value['category_name'] . ')';

            }else{
                $value['category_name'] = '未设置中文' . '(' . $value['category_name'] . ')';
            }
            unset($value['category_name_chinese']);
        }
        return $cate_list;

    }

如上就是获取最低类目的思路逻辑。

Original: https://www.cnblogs.com/camg/p/16135435.html
Author: 在斑马线上散布
Title: 如何根据父类id关联获取所以最低级类目

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/602359/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球